# **FUJITSU SEMICONDUCTOR**

MICROCONTROLLER MANUAL

# F<sup>2</sup>MC-8L FAMILY 8-BIT MICROCONTROLLER MB89990 Series HARDWARE MANUAL



# F<sup>2</sup>MC-8L FAMILY 8-BIT MICROCONTROLLER MB89990 Series HARDWARE MANUAL

# **PREFACE**

# Preface describes objectives and intended reader.

# ■ Objectives and Intended Reader

The MB89990 series of microcontrollers are mid-range of microcontroller. They are general-purpose and high-speed products in the  $F^2MC-8L$  Family series of 8-bit single-chip microcontrollers operating at low voltages. It has Timer, Remote-control transmission frequency generator.

This manual covers the functions and operations of the MB89990 series of microcontrollers. Refer to the  $F^2MC-8L$  Family Software Manual for instructions.

- 1. The contents of this document are subject to change without notice. Customers are advised to consult with FUJITSU sales representatives before ordering.
- 2. The information and circuit diagrams in this document are presented as examples of semiconductor device applications, and are not intended to be incorporated in devices for actual use. Also, FUJITSU is unable to assume responsibility for infringement of any patent rights or other rights of third parties arising from the use of this information or circuit diagrams.
- 3. The contents of this document may not be reproduced or copied without the permission of FUJITSU LIMITED.
- 4. FUJITSU semiconductor devices are intended for use in standard applications (computers, office automation and other office equipments, industrial, communications, and measurement equipments, personal or household devices, etc.).

#### **CAUTION:**

Customers considering the use of our products in special applications where failure or abnormal operation may directly affect human lives or cause physical injury or property damage, or where extremely high levels of reliability are demanded (such as aerospace systems, atomic energy controls, sea floor repeaters, vehicle operating controls, medical devices for life support, etc.) are requested to consult with FUJITSU sales representatives before such use. The company will not be responsible for damages arising from such use without prior approval.

- 5. Any semiconductor devices have inherently a certain rate of failure. You must protect against injury, damage or loss from such failures by incorporating safety design measures into your facility and equipment such as redundancy, fire protection, and prevention of over-current levels and other abnormal operating conditions.
- 6. If any products described in this document represent goods or technologies subject to certain restrictions on export under the Foreign Exchange and Foreign Trade Control Law of Japan, the prior authorization by Japanese government should be required for export of those products from Japan.

# **CONTENTS**

| CHAP | TER 1 GENARAL                              |    |
|------|--------------------------------------------|----|
| 1.1  | Features                                   |    |
| 1.2  | Product Series                             |    |
| 1.3  | Block Diagram                              |    |
| 1.4  | Pin Assignment                             | 6  |
| 1.5  | Pin Function Description                   | 8  |
| 1.6  | Handling Devices                           | 12 |
| СНАР | TER 2 HARDWARE CONFIGRATION                | 13 |
| 2.1  | CPU                                        | 14 |
| 2.2  | Lock Control Block                         | 19 |
| 2.3  | Interrupt Controller                       | 25 |
| 2.4  | I/O Ports                                  | 28 |
| 2.5  | 8/16-bit Timer (Timer 1 and Timer 2)       | 32 |
| 2.6  | External Interrupt 1                       | 39 |
| 2.7  | External Interrupt 2 (Wake Up)             | 43 |
| 2.8  | Remote-control Carrier Frequency Generator | 45 |
| 2.9  | Time-base Timer                            | 48 |
| 2.10 | Watchdog Timer Reset                       | 51 |
| СНАР | TER 3 OPERATION                            | 53 |
| 3.1  | Clock Pulse Generator                      | 54 |
| 3.2  | Reset                                      | 55 |
| 3.2  | 2.1 Reset Operation                        | 56 |
| 3.2  | 2.2 Reset Source                           | 57 |
| 3.3  | Interrupt                                  | 58 |
| 3.4  | Low-power Consumption Modes                | 60 |
| 3.5  | Pin States for Sleep, Stop and Reset       | 61 |
| СНАР | TER 4 INSTRUCTIONS                         | 63 |
| 4.1  | Transfer Instructions                      | 64 |
| 4.2  | Operation Instruction                      | 66 |
| 4.3  | Branch Instructions                        | 68 |
| 4.4  | Other Instructions                         | 69 |
| 4.5  | F2MC-8L Family Instruction Map             | 70 |
| CHAP | TER 5 MASK OPTIONS                         | 71 |
| 5.1  | Mask Options                               |    |
| APPE | NDIX                                       | 73 |
|      | PENDIX A I/O Map                           |    |
|      | PENDIX R FPROM Setting for MR89P195        |    |

# **FIGURES**

| Figure 1.4-1 | Pin Assignment (FPT-28P-M02, DIP-28P-M03)                            | 6  |
|--------------|----------------------------------------------------------------------|----|
| Figure 1.4-2 | Pin Assignment (MQP-48C-P01)                                         | 7  |
| Figure 2.1-1 | Memory Space of MB89990 Series of Microcontrollers                   | 14 |
| Figure 2.1-2 | Arrangement of 16 bit Data in Memory                                 | 16 |
| Figure 2.1-3 | Arrangement of 16-bit Data during Execution of Instruction           | 16 |
| Figure 2.1-4 | Structure of Processor Status                                        | 17 |
| Figure 2.1-5 | Rule for Translating Real Addresses at General-purpose Register Area | 17 |
| Figure 2.1-6 | Register Bank Configuration                                          | 18 |
| Figure 2.3-1 | Interrupt-processing Flowchart                                       | 27 |
| Figure 2.4-1 | Ports 00 to 07 and 30 to 37                                          | 30 |
| Figure 2.4-2 | Ports 40 to 45                                                       | 31 |
| Figure 2.5-1 | 8/16-bit Timer Block Diagram                                         | 32 |
| Figure 2.5-2 | Description Diagram for Internal Clock Mode Operation                | 36 |
| Figure 2.5-3 | Flow Diagram for Timer Setting                                       | 36 |
| Figure 2.5-4 | Initialization of Equivalent Circuit                                 | 37 |
| Figure 2.5-5 | External Cock Mode Operation Description Diagram                     | 37 |
| Figure 2.5-6 | Operation Diagram when Timer Stop Bit is Used                        | 38 |
| Figure 3.1-1 | Clock Pulse Generator                                                | 54 |
| Figure 3.2-1 | Outline of Reset Operation                                           | 56 |
| Figure 3.2-2 | Reset Vector Structure                                               | 56 |
| Figure 3.3-1 | Interrupt-processing Flowchart                                       | 58 |

# **TABLES**

| Table 1.2-1 | Types and Functions of MB89990 Series of Microcontrollers | 3  |
|-------------|-----------------------------------------------------------|----|
| Table 1.5-1 | Pin Function Description                                  | 8  |
| Table 1.5-2 | Pins for External ROM                                     | 9  |
| Table 1.5-3 | Input/Output Circuit Configurations                       | 10 |
| Table 2.1-1 | Table of Reset and Interrupt Vectors                      | 15 |
| Table 2.2-1 | Opeating State of Low-power Consumption Modes             | 21 |
| Table 2.2-2 | Selection of Oscillation Stabilization Time               | 22 |
| Table 2.2-3 | Sources of Reset                                          | 24 |
| Table 2.4-1 | List of Port Functions                                    | 28 |
| Table 3.3-1 | Interrupt Sources and Interrupt Vectors                   | 59 |
| Table 3.4-1 | Low-power Consumption Mode at Each Clock Mode             | 60 |
| Table 3.5-1 | Pin State of MB89990                                      | 61 |
| Table 5.1-1 | Mask Options                                              | 72 |

# CHAPTER 1 GENARAL

The MB89990 series contains microcontrollers with a full range of resources such as timers, external interrupts, and remote-control function, as well as the F<sup>2</sup>MC-8L CPU core for low-voltage and high-speed operation. This single-chip microcontroller is suitable for small devices such as remote controllers incorporating compact packages.

- 1.1 Features
- 1.2 Product Series
- 1.3 Block Diagram
- 1.4 Pin Assignment
- 1.5 Pin Function Description
- 1.6 Handling Devices

# 1.1 Features

## This section describes the features.

#### ■ Features

- Minimum instruction execution time: 0.95  $\mu$ s at 4.2 MHz (V<sub>CC</sub> = 3 V)
- CPU core common to F<sup>2</sup>MC-8L CPU
  - Instruction set suitable for controller: Multiply/subtraction instruction, 16-bit operation,
     Instruction test and branch instruction, Bit operation instruction
- · Two timers
  - 8/16-bit timer/counter
  - 20-bit time-base counter
- · External interrupts
  - Edge detection: 3 pins (edge direction enabled)
  - Low-level interrupt: 8 pins (wake-up)
- Built-in remote-control carrier frequency generator
- Low-power consumption modes
  - · Stop mode: Almost no power consumption because oscillation stopped
  - Sleep mode: 33% of normal power consumption because CPU stopped
- Package: SOP-28, SH-DIP-28 (mask ROM only)

# 1.2 Product Series

This section describes the product series.

## **■** Product Series

Table 1.2-1 "Types and Functions of MB89990 Series of Microcontrollers" lists the types and functions of the MB89990 series of microcontrollers.

Table 1.2-1 Types and Functions of MB89990 Series of Microcontrollers

| Model Name                       | MB89997                                                                                                                                                                                                                       |                                                              | MB89P195*                                                                        | MB89PV190*                      |
|----------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------|----------------------------------------------------------------------------------|---------------------------------|
| Classification                   | Mass-produced product (mask ROM product)                                                                                                                                                                                      |                                                              | One-time product                                                                 | For evaluation and development  |
| ROM capacity                     | 32 K × 8 bits<br>(internal ROM)                                                                                                                                                                                               |                                                              | 16 K × 8 bits<br>(internal ROM,<br>write enable by<br>general-purpose<br>writer) | 32 K × 8 bits<br>(external ROM) |
| RAM capacity                     | 128 × 8 bits                                                                                                                                                                                                                  |                                                              | 256 ×                                                                            | 8 bits                          |
| CPU functions                    | Number of basic instructions Instruction bit length Instruction length Data bit length Minimum instruction execution time Interrupt processing time                                                                           | nstructions<br>3 bytes<br>16 bits<br>µs/4.2 MHz<br>s/4.2 MHz |                                                                                  |                                 |
| Port                             | I/O port (N-ch open drain)6 pinsI/O port (CMOS)16 pirTotal22 pir                                                                                                                                                              |                                                              | ns (13 used as resource pins)                                                    |                                 |
| Timer counter                    | 2 channels 8-bit counter or 1 channel 16-bit counte                                                                                                                                                                           |                                                              |                                                                                  |                                 |
| External-interrupt 1             | 3 independent channels (edge selection, interrupt vector, interrupt source flag) Interrupt mode selectable from rising edge, falling edge, or both edges For releasing Stop/Sleep modes (edge detection in Stop mode enabled) |                                                              |                                                                                  |                                 |
| External-interrupt 2 (Wake-up)   | 8 channels (Low-level interrupt enabled)                                                                                                                                                                                      |                                                              |                                                                                  |                                 |
| Remote-control carrier frequency | Pulse width and cycle are programmable                                                                                                                                                                                        |                                                              |                                                                                  |                                 |
| Standby mode                     | Sleep and Stop modes                                                                                                                                                                                                          |                                                              |                                                                                  |                                 |
| Process                          | CMOS                                                                                                                                                                                                                          |                                                              |                                                                                  |                                 |
| Package                          | FPT-28P-M02, DIP-28P-M03                                                                                                                                                                                                      | FPT-28P-M02                                                  | MQP-48C-P01                                                                      |                                 |
| Operating voltage                | 2.2 to 6.0 V** 2.7V to 6.0 V                                                                                                                                                                                                  |                                                              |                                                                                  | o 6.0 V                         |

## **CHAPTER 1 GENARAL**

- \* The MB89P195 microtroller is the one-time product for the MB89190 series which can be also be used for the MB89990 series.
- \* The MB89PV190 microtroller is the evaluation and development product for the MB89190 series which can be also be used for the MB89990 series.
- \*\* Operating voltage varies with conditions such as frequency or others. See the data sheet for details.

# 1.3 Block Diagram

This section describes the block diagram.

# **■** Block Diagram



# 1.4 Pin Assignment

This section describes the pin assignment.

# **■** Pin Assignment

Figure 1.4-1 Pin Assignment (FPT-28P-M02, DIP-28P-M03)





Figure 1.4-2 Pin Assignment (MQP-48C-P01)

<sup>\*</sup> Pin assignment on package top (only for piggyback/evaluation product)

| Pin No. | Symbol   | Pin No. | Symbol | Pin No. | Symbol          | Pin No. | Symbol |
|---------|----------|---------|--------|---------|-----------------|---------|--------|
| 49      | $V_{PP}$ | 57      | NC     | 65      | 04              | 73      | ŌĒ     |
| 50      | A12      | 58      | A2     | 66      | 05              | 74      | NC     |
| 51      | A7       | 59      | A1     | 67      | 06              | 75      | A11    |
| 52      | A6       | 60      | A0     | 68      | 07              | 76      | A9     |
| 53      | A5       | 61      | 01     | 69      | <u>08</u><br>CE | 77      | A8     |
| 54      | A4       | 62      | 02     | 70      | CE              | 78      | A13    |
| 55      | A3       | 63      | 03     | 71      | A10             | 79      | A14    |
| 56      | NC       | 64      | GND    | 72      | NC              | 80      | Vcc    |

# 1.5 Pin Function Description

# This section describes the pin functions.

# ■ Pin Function Description

Table 1.5-1 "Pin Function Description" and Table 1.5-2 "Pins for External ROM" list the pin function and Table 1.5-3 "Input/Output Circuit Configurations" shows the input/output circuit configurations.

**Table 1.5-1 Pin Function Description** 

| Pin No.  | Pin Name                     | Circuit type | Function                                                                                                                                                                                                                        |
|----------|------------------------------|--------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 7        | X0                           | А            | Clock oscillator pins                                                                                                                                                                                                           |
| 8        | X1                           | Λ            | Glock decinator pine                                                                                                                                                                                                            |
| 5        | TEST                         | В            | <b>Test input pin</b> These pins are connected directly to V <sub>SS</sub> .                                                                                                                                                    |
| 6        | RST                          | С            | Reset I/O pin This pin consists of an N-ch open-drain output with a pull-up resistor and hysteresis input. A Low level is output from this pin by internal source. The internal circuit is initialized at input of a Low level. |
| 24 to 27 | P00/INT20<br>to<br>P03/INT23 | D            | General-purpose I/O port These ports also serve as external interrupt input pin. The external interrupt input is hysteresis type.                                                                                               |
| 1 to 4   | P04/INT24<br>to<br>P07/INT27 | D            | General-purpose I/O port These ports also serve as external interrupt input pin. The external interrupt input is hysteresis type.                                                                                               |
| 17       | P30                          | E            | General-purpose I/O port                                                                                                                                                                                                        |
| 16       | P31                          | Е            | General-purpose I/O port                                                                                                                                                                                                        |
| 15       | P32                          | Е            | General-purpose I/O port                                                                                                                                                                                                        |
| 14       | P33/EC                       | D            | General-purpose I/O port This port also serves as an external clock input pin for the 8-bit timer/counter. The external clock input is hysteresis type with a built-in noise filter.                                            |
| 13       | P34/T0/INT10                 | D            | General-purpose I/O port This port also serves as an overflow output pin and an external interrupt input pin for the 8-bit timer/counter. The external interrupt input is hysteresis type with a built-in noise filter.         |
| 12       | P35/INT11                    |              | General-purpose I/O port                                                                                                                                                                                                        |
| 11       | P36/INT12                    | D            | This port also serves as an external interrupt input pin. The external interrupt input is hysteresis type with a built-in noise filter.                                                                                         |

**Table 1.5-1 Pin Function Description (Continued)** 

| Pin No.  | Pin Name        | Circuit type | Function                                                                     |
|----------|-----------------|--------------|------------------------------------------------------------------------------|
| 10       | P37/RCO         | E            | General-purpose I/O port This port also serves as remote-control output pin. |
| 18 to 23 | P40 to P45      | F            | N-ch open-drain type I/O port                                                |
| 28       | V <sub>CC</sub> | _            | Power pin                                                                    |
| 9        | V <sub>SS</sub> | _            | Power (GND) pin                                                              |

Table 1.5-2 Pins for External ROM

| Pin No. | Pin Name        | Circuit type | Functinon                                                           |
|---------|-----------------|--------------|---------------------------------------------------------------------|
| 49      | V <sub>PP</sub> | Output       | High-level output pin                                               |
| 79      | A14             |              |                                                                     |
| 78      | A13             |              |                                                                     |
| 50      | A12             |              |                                                                     |
| 75      | A11             |              |                                                                     |
| 69      | A10             |              |                                                                     |
| 76      | A9              |              |                                                                     |
| 77      | A8              |              |                                                                     |
| 51      | A7              | Output       | Address-output pins                                                 |
| 52      | A6              |              |                                                                     |
| 53      | A5              |              |                                                                     |
| 54      | A4              |              |                                                                     |
| 55      | A3              |              |                                                                     |
| 58      | A2              |              |                                                                     |
| 59      | A1              |              |                                                                     |
| 60      | A0              |              |                                                                     |
| 61      | 01              |              |                                                                     |
| 62      | 02              |              |                                                                     |
| 63      | 03              |              |                                                                     |
| 65      | 04              | Intout       | Data-input pins                                                     |
| 66      | 05              | Intput       | Data-Input pins                                                     |
| 67      | 06              |              |                                                                     |
| 68      | 07              |              |                                                                     |
| 69      | 08              |              |                                                                     |
| 70      | CE              | Output       | Chip-enable pin for ROM A High level is output in the standby mode. |
|         |                 |              |                                                                     |
| 73      | ŌĒ              | Output       | Output-enable pin for ROM A Low level is always output.             |
| 80      | V <sub>CC</sub> | Output       | Power pin for EPROM                                                 |
| 64      | V <sub>SS</sub> | Output       | Power (GND) pin                                                     |

# **CHAPTER 1 GENARAL**

**Table 1.5-3 Input/Output Circuit Configurations** 

| Classification | Circuit                               | Remarks                                                                                                 |
|----------------|---------------------------------------|---------------------------------------------------------------------------------------------------------|
| А              | Standby control signal                | Crystal oscillator     Feedback resistor: About 1 MΩ/5V (1 to 5MHz)                                     |
| В              |                                       | CMOS input                                                                                              |
| С              | R R R R R R R R R R R R R R R R R R R | <ul> <li>Output pull-up resistor (P-ch):         About 50 kΩ (5 V)</li> <li>Hysteresis input</li> </ul> |
| D              | Pch Pch Nch                           | CMOS input/output     Hysteresis input (resorce input)     The pull-up resistor is available.           |

Table 1.5-3 Input/Output Circuit Configurations (Continued)

| Classification | Circuit              | Remarks                                                                                                                                |
|----------------|----------------------|----------------------------------------------------------------------------------------------------------------------------------------|
| E              | Pch Pch Nch          | CMOS input/output     The pull-up resistor is available.                                                                               |
| F              | Pch Nch Analog input | <ul> <li>N-ch open-drain output</li> <li>Analog input</li> <li>The pull-up resistor is available.<br/>(MB89990 series only)</li> </ul> |

# 1.6 Handling Devices

# This section describes handling devices.

# ■ Handling Devices

## (1) Preventing latch-up

Latch-up may occur if a voltage higher than  $V_{CC}$  or lower than  $V_{SS}$  is applied to the input or output pins other than middle- and high-level-resistant pins, or if voltage exceeding the rated value is applied between  $V_{CC}$  and  $V_{SS}$ . When latch-up occurs, the supply current increases rapidly, sometimes resulting in overheating and destruction. Therefore, no voltage exceeding the maximum ratings should be used.

## (2) Handling unused input pins

Leaving unused input pins open may cause a malfunction. Therefore, these pins should be set to pull-up or pull-down.

## (3) Variations in supply voltage

Although the specified  $V_{CC}$  supply voltage operating range is assured, a sudden change in the supply voltage within the specified range may cause a malfunction. Therefore, the voltage supply to the IC should be kept as constant as possible. The  $V_{CC}$  ripple (P-P value) at the supply frequency (50 to 60 Hz) should be less than 10% of the typical  $V_{CC}$  value, or the coefficient of excessive variation should be less than 0.1 V/ms instantaneous change when the power supply is switched.

#### (4) Precautions for external clocks

It takes some time for oscillation to stabilize after changing the mode from power-on reset (option selection) and stop mode. Consequently, an external clock must be input.

## (5) Recommended screening conditions

The OPTROM product should be screened by high-temperature aging before mounting.



The programming test cannot be performed for all bits of the preprogrammed OPTROM product due to its characteristics. Consequently, 100% programming yielding cannot be ensured.

# This chapter describes each block of the CPU hardware.

- 2.1 CPU
- 2.2 Clock Control Block
- 2.3 Interrupt Controller
- 2.4 I/O Ports
- 2.5 8/16-bit Timer (Timer 1 and Timer 2)
- 2.6 External Interrupt 1
- 2.7 External Interrupt 2 (Wake up)
- 2.8 Remote-control Carrier Frequency Generator
- 2.9 Time-base Timer
- 2.10 Watchdog Timer Reset

# 2.1 CPU

This section describes the memory space and register composing CPU hardware.

# ■ Memory Space

The MB89990 series of microcontrollers have a memory area of 64K bytes. All I/O, data areas, and program areas are located in this space. The I/O area is at the lowest address and the data area is immediately above it. The data area may be divided into register, stack, and direct-address areas according to the applications. The program area is located near the highest address and the tables of interrupt and reset vectors and vector-call instructions are at the highest address. Figure 2.1-1 "Memory Space of MB89990 Series of Microcontrollers" shows the structure of the memory space for the MB89990 series of microcontrollers.

MB89P195 MB89997 MB89PV190 0000н 0000H 0000H I/O I/O I/O 0080н 0080⊦ 0080 Vacant area **RAM** RAM 00С0н 0100н 0100⊦ 0100н RAM Register Register Register 0140 0180+ Vacant area Vacant area Vacant area 8000H 8000H C000+ Program PROM (Mask ROM) External ROM Mask ROM **FFFF**⊦ **FFFF**<sub>+</sub> **FFFF**<sub>H</sub>

Figure 2.1-1 Memory Space of MB89990 Series of Microcontrollers

#### I/O area

 This area is where various resources such as control and data registers are located. The memory map for the I/O area is given in APPENDIX A.

## RAM area

This area is where the static RAM is located. Addresses from 0100<sub>H</sub> to 017F<sub>H</sub> (0100<sub>H</sub> to 013F<sub>H</sub> for the MB89997) are also used as the general-purpose register area.

## ROM area

This area is where the internal ROM is located. Addresses from FFC0<sub>H</sub> to FFFF<sub>H</sub>are also

used for the table of reset and vector-call instructions. Table 2.1-1 "Table of Reset and Interrupt Vectors" shows the correspondence between each interrupt number or reset and the table addresses to be referenced for the MB89990 series of microcontrollers.

Table 2.1-1 Table of Reset and Interrupt Vectors

|          | Table address     |                   |  |
|----------|-------------------|-------------------|--|
|          | Upper data        | Lower data        |  |
| CALLV #0 | FFC0 <sub>H</sub> | FFC1 <sub>H</sub> |  |
| CALLV #1 | FFC2 <sub>H</sub> | FFC3 <sub>H</sub> |  |
| CALLV #2 | FFC4 <sub>H</sub> | FFC5 <sub>H</sub> |  |
| CALLV #3 | FFC6 <sub>H</sub> | FFC7 <sub>H</sub> |  |
| CALLV #4 | FFC8 <sub>H</sub> | FFC9 <sub>H</sub> |  |
| CALLV #5 | FFCA <sub>H</sub> | FFCB <sub>H</sub> |  |
| CALLV #6 | FFCCH             | FFCD <sub>H</sub> |  |
| CALLV #7 | FFCEH             | FFCF <sub>H</sub> |  |

|               | Table address     |                   |  |  |
|---------------|-------------------|-------------------|--|--|
|               | Upper data        | Lower data        |  |  |
| Interrupt #11 | FFE4 <sub>H</sub> | FFE5 <sub>H</sub> |  |  |
| Interrupt #10 | FFE6 <sub>H</sub> | FFE7 <sub>H</sub> |  |  |
| Interrupt #9  | FFE8 <sub>H</sub> | FFE9 <sub>H</sub> |  |  |
| Interrupt #8  | FFEA <sub>H</sub> | FFEBH             |  |  |
| Interrupt #7  | FFECH             | FFEDH             |  |  |
| Interrupt #6  | FFFE <sub>H</sub> | FFEFH             |  |  |
| Interrupt #5  | FFF0 <sub>H</sub> | FFF1 <sub>H</sub> |  |  |
| Interrupt #4  | FFF2H             | FFF3 <sub>H</sub> |  |  |
| Interrupt #3  | FFF4 <sub>H</sub> | FFF5 <sub>H</sub> |  |  |
| Interrupt #2  | FFF6 <sub>H</sub> | FFF7 <sub>H</sub> |  |  |
| Interrupt #1  | FFF8H             | FFF9 <sub>H</sub> |  |  |
| Interrupt #0  | FFFA <sub>H</sub> | FFFB <sub>H</sub> |  |  |
| Reset mode    |                   | FFFDH             |  |  |
| Reset vector  | FFFE <sub>H</sub> | FFFFH             |  |  |

#### Note:

 $\mathtt{FFFC}_{H} \text{ is already reserved}.$ 

Set  $\tt 00_H$  for  $\tt FFFD_H$  in the Reset mode.

#### ■ Arrangement of 16-bit Data in Memory

When the MB89990 series of microcontrollers handle 16-bit data, the data written at the lower address is treated as the upper data and that written at the next address is treated as the lower data as shown in Figure 2.1-2 "Arrangement of 16 bit Data in Memory".

Figure 2.1-2 Arrangement of 16 bit Data in Memory



This is the same as when 16 bits are specified by the operand during execution of an instruction. Bits closer to the OP code are treated as the upper byte and those next to it are treated as the lower byte. This is also the same when the memory address or 16-bit immediate data is specified by the operand.

Figure 2.1-3 Arrangement of 16-bit Data during Execution of Instruction



Data saved in the stack by an interrupt is also treated in the same manner.

# ■ Internal Registers in CPU

The MB89990 series of microcontrollers have dedicated registers specified applications in the CPU and general-purpose registers in memory.

| • | Program counter (PC)      | 16-bit long register indicating location where instructions stored                                                                                                       |
|---|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| • | Accumulator (A)           | 16-bit long register where results of operations stored temporarily. The lower byte is used to execute 8-bit data processing instructions.                               |
| • | Temporary accumulator (T) | 16-bit long register where the operations are performed between this register and the accumulator. The lower byte is used to execute 8-bit data processing instructions. |
| • | Stack pointer (SP)        | 16-bit long register indicating stack area                                                                                                                               |

Processor status (PS)
 16-bit long register where register pointers and condition codes stored

Index register (IX)
 16-bit long register for index modification

Extra pointer (EP)
 16-bit long register for memory addressing



The 16 bits of the processor status (PS) can be divided into 8 upper bits for a register bank pointer (RP) and 8 lower bits for a condition code register (CCR). (See Figure 2.1-4 "Structure of Processor Status".)

Figure 2.1-4 Structure of Processor Status



The RP indicates the address of the current register bank. The contents of the RP and the real addresses are translated as shown in Figure 2.1-5 "Rule for Translating Real Addresses at General-purpose Register Area" .

Figure 2.1-5 Rule for Translating Real Addresses at General-purpose Register Area



The CCR has bits indicating the results of operations and transfer data contents, and bits controlling the CPU operation when an interrupt occurs.

- H-flag is set when a carry or a borrow out of bit 3 into bit 4 is generated as a result of operations. It is cleared in other cases. This flag is used for decimal-correction instructions.

- I-flag An interrupt is enabled when this flag is 1 and is disabled when it is 0. The I-flag is 0 at reset.

- IL1 and IL0 These bits indicate the level of the currently-enabled interrupt. The Interrupt Processing executes interrupt processing only when an interrupt with a value smaller than the value indicated by this bit is requested.

| IL1 | IL0 | Interrupt level | High and low       |
|-----|-----|-----------------|--------------------|
| 0   | 0   | 4               | High               |
| 0   | 1   | 1               | 1                  |
| 1   | 0   | 2               |                    |
| 1   | 1   | 3               | Low = No interrupt |

N-flag
 The N-flag is set when the most significant bit is 1 as a result of operations. It is cleared when the MSB is 0.
 Z-flag is set when the bit is 0 as a result of operations. It is cleared in other cases.
 V-flag is set when a twois complement overflow occurs as a result of operations. It is reset when an overflow does not occur.
 C-flag is set when a carry or a borrow out of bit 7 is generated as a result of operations. It is cleared in other cases. When the shift

## · General-purpose registers

General-purpose registers are 8-bit long registers for storing data.

The 8-bit long general-purpose registers are in the register banks in memory. One bank has eight registers and up to 16 banks are available for the MB89193 (8 banks for the MB89191). The register bank pointer (RP) indicates the currently-used bank.

instruction is executed, the value of the C-flag is shifted out.

Memory area

Address = 0100<sub>H</sub> + 8 × (RP)

R1

R2

R3

R4

R5

R6

R7

16 banks

Figure 2.1-6 Register Bank Configuration

# 2.2 Lock Control Block

• This block controls the standby operation and software reset.

# ■ Machine Clock Control Block Diagram



# ■ Register List



# **■** Description of Registers

The detail of each register is described below.

• Standby-control register (STBC)

Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 Address: 0008<sub>H</sub> STP SLP SPL **RST** (W) (W) (R/W) (W) Intilial value 0001XXXX<sub>B</sub>

[Bit 7] STP: Stop bit

This bit is used to specify switching CPU to the stop mode.

| 0 | No operation |
|---|--------------|
| 1 | Stop mode    |

This bit is cleared at reset or stop cancellation.

0 is always read when this bit is read.

[Bit 6] SLP: Sleep bit

This bit is used to specify switching the CPU and resources to the sleep mode.

| 0 | No operation |
|---|--------------|
| 1 | Sleep mode   |

This bit is cleared at reset, sleep or stop cancellation.

0 is always read when this bit is read.

[Bit 5] SPL: Pin state specifying bit

This bit is used to specify the external pin state in the stop mode.

| 0 | Holds state and level immediately before stop mode |
|---|----------------------------------------------------|
| 1 | High impedance                                     |

This bit is cleared at resetting.

[Bit 4] RST: Software reset bit

This bit is used to specify the software reset.

| 0 | Generates 4-cycle reset signal |
|---|--------------------------------|
| 1 | No operation                   |

<sup>1</sup> is always read when this bit is read.

#### ■ Description of Operation

Main/sub clock block has normal and low-power consumption mode. The low-power consumption mode are described below.

#### (1) Low-power consumption mode

This chip has three operation modes. The sleep mode and stop mode in the table below reduce the power consumption.

Table 2.2-1 Opeating State of Low-power Consumption Modes

| Clock mode | Clock pulse | Each operating clock pulse<br>(4 Mhz clock) |                 |               | Wake-up source    |
|------------|-------------|---------------------------------------------|-----------------|---------------|-------------------|
| of CPU     |             | CPU                                         | Time base timer | Each resource | in each mode      |
| RUN        | Oscillates  | 2.0 MHz                                     | 2.0 MHz         | 2.0 MHz       | Various interrupt |
| Sleep      | Oscillates  | Stops                                       | 2.0 1011 12     | 2.0 1/11/12   | requests          |
|            |             | Stops                                       |                 |               |                   |

- The SLEEP mode stops only the operating clock pulse of the CPU. Other operations are continued.
- The STOP mode stops the oscillation. Data can be held with the lowest power consumption in this mode.

### (a) SLEEP state

- Switching to Sleep State
  - Writing 1 at the SLP bit (bit6) of the STBC register switches the mode to SLEEP state.
  - The SLEEP state is the mode to stop clock pulse operating the CPU. Only the CPU stops and the resources continue to operate.
  - If an interrupt is requested when 1 is written at the SLP bit (bit 6), instruction execution continues without switching to the SLEEP state.
  - In the SLEEP state, the values of registers and RAM immediately before entering the SLEEP state are held.

### · Cancelling SLEEP state

- The SLEEP state is cancelled by inputting the reset signal and requesting an interrupt.
- When the reset signal is input during the SLEEP state, the CPU is switched to the reset state and the SLEEP state is cancelled.
- When an interrupt level higher than 11 is requested from a resource during the SLEEP state, the SLEEP state is cancelled.
- When the I flag and IL bit are enabled interrupt like an ordinary interrupt after cancelling, the CPU executes the interrupt processing. When they are disabled, the CPU executes the interrupt processing from the instruction next to the one before entering the SLEEP state.

#### (b) STOP state

- Switching to STOP state
  - Writing 1 at the STP bit (bit7) of the STBC register switches the mode to STOP state.
  - In the STOP state, the clock oscillation, CPU, and all resources are stopped.

- The input/output pins and output pins during the STOP state can be controlled by the SPL bit (bit5) of the STBC register so that they are held in the state immediately before entering the STOP state, or so that they enter in the high-impedance state.
- If an interrupt is requested when 1 is written at the STP bit (bit 7), instruction execution continues without switching to the STOP state.
- In the STOP state, the values of registers and RAM immediately before entering the STOP state are held.

#### Cancelling STOP state

- The STOP state is cancelled either by inputting the reset signal or by requesting an interrupt.
- When the reset signal is input during the STOP state, the CPU is switched to the reset state and the STOP state is cancelled.
- When an interrupt higher than level 11 is requested from the external interrupt circuit during the STOP state, the STOP state is cancelled.
- When the I flag and IL bit are enabled interrupt like an ordinary interrupt after cancelling, the CPU executes the interrupt processing. When they are disabled, the CPU executes the interrupt processing from the instruction next to the one before entering the STOP state.
- The oscillation stabilization time can be selected by the option from any of the four types listed in Table 2.2-2 "Selection of Oscillation Stabilization Time".
- If the STOP state is cancelled by inputting the reset signal, the CPU is switched to the
  oscillation stabilization wait state. Therefore, the reset sequence is not executed unless
  the oscillation stabilization time is elapsed. The oscillation stabilization time corresponds
  to the oscillation stabilization time of the main clock selected by the option. However,
  when Power-on Reset is not specified by the mask option, the CPU is not switched to the
  oscillation stabilization wait state even if the STOP state is cancelled by inputting the
  reset signal.

**Table 2.2-2 Selection of Oscillation Stabilization Time** 

| Ocillation stabilization time | Ocillation stabilization time with 4 MHz source clock |
|-------------------------------|-------------------------------------------------------|
| 2 <sup>18</sup> /f*           | Approximate 65.5 ms                                   |
| 2 <sup>16</sup> /f*           | Approximate 16.4 ms                                   |
| 2 <sup>12</sup> /f*           | Approximate 1.2 ms                                    |
| 2 <sup>2</sup> /f*            | Approximate 0 ms                                      |

\* f = source clock frequency

(2) State transition diagram at low power consumption mode



- (a) When power-on reset option selected
- (b) When power-on reset option not selected
- (c) After oscillation stabilized
- (d) Set STP bit to 1.
- (e) Set SLP bit to 1.
- (f) External reset when power-on reset option not selected
- (g) External reset or interrupt when power-on reset option selected
- (h) External reset or interrupt

#### ■ Reset Control Section



- Reset
  - There are four types of resets as shown in Table 2.2-3 "Sources of Reset".

Table 2.2-3 Sources of Reset

| Reset name         | Description                         |
|--------------------|-------------------------------------|
| Power-on reset     | Turns power on                      |
| Watchdog reset     | Overflows watchdog timer            |
| External-pin reset | Sets external-reset pin to Low      |
| Software reset     | Writes 0 at RST bit (bit 4) of STBC |

When the power-on reset and reset during the stop state are used, the oscillation stabilization time is needed after the oscillator operates because the oscillator stops. The time-base timer controls this stabilization time. Consequently, the operation does not start immediately even after cancelling the reset.

However, if the mask option without Power-on Reset is selected, no oscillation stabilization time is required in any state after external pins have been released from the reset.

#### Note:

When resetting a product without the power-on reset function, set a longer time than the optional oscillation stabilization time. Otherwise, the reset timing matches the AC characteristics.

# 2.3 Interrupt Controller

• The interrupt controller for the F<sup>2</sup>MC-8L family is located between the CPU and each resource. This controller receives interrupt requests from the resources, assigns priority to them, and transfers the priority to the CPU. It also decides the priority of same-level interrupts.

## ■ Block Diagram



# ■ Register List

Interrupt controller consists of interrupt-level registers (ILR1, 2, and 3) and interrupt-test register (ITR).



## **■** Description of Registers

The detail of each register is described below.

(1) Interrupt levei setting register (ILR1 to ILR3)

Bit 7 Bit 6 Bit 4 Bit 3 Bit 1 Bit 0 Bit 5 Bit 2 Address: 007C<sub>H</sub> L31 L30 L21 L20 L01 L00 L11 L10 Address: 007DH L71 L70 L61 L60 L51 L50 L41 L40 Address: 007E<sub>H</sub> LB1 LB0 LA1 LA0 L91 L90 L81 L80

> Intilial value 11111111

The ILRX sets the interrupt level of each resource. The digits in the center of each bit correspond to the interrupt numbers.



When an interrupt is requested from each resource, the interrupt controller transfers the interrupt level based on the value set at the 2 bits of the ILRX corresponding to the interrupt to the CPU.

A relation between two bits of the ILRX and the interrupt level required is shown below.

| Lx1 | Lx0 | Required interrupt level |
|-----|-----|--------------------------|
| 0   | Х   | 1                        |
| 1   | 0   | 2                        |
| 1   | 1   | 3 (None)                 |

(2) Interrupt test register (ITR)

|                            | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1 | Bit 0 |
|----------------------------|-------|-------|-------|-------|-------|-------|-------|-------|
| Address: 007F <sub>H</sub> | _     | _     | _     | _     | _     | _     | *     | *     |

The ITR used for testing. Do not access it.

## **■** Description

The functions of interrupt controllers are described below.

- Interrupt functions
  - The MB89990 series of microcontrollers have 4 inputs for interrupt requests from each resource. The interrupt level can be set by 2-bit registers corresponding to each input. When an interrupt can be requested from a resource, the interrupt controller receives it and transfers the contents of the corresponding level register to the CPU. The interrupt to the device is processed as follows:
  - (a) An interrupt source is generated inside each resource.
  - (b) If an interrupt is enabled, an interrupt request is output from each resource to the interrupt controller by referring to the interrupt-enable bit inside each resource.
  - (c) After receiving this interrupt request, the interrupt controller determines the priority of simultaneously-requested interrupts and then transfers the interrupt level for the applicable interrupt to the CPU.
  - (d) The CPU compares the interrupt level requested from the interrupt controller with the IL bit in the processor status register.
  - (e) As a result of the comparison, if the priority of the interrupt level is higher than that of the current interrupt processing level, the contents of the I-flag in the same processor status register are checked.
  - (f) As a result of the check in step (e), if the I-flag is enabled for an interrupt, the contents of the IL bit are set to the required level. As soon as the currently-executing instruction is terminated, the CPU performs the interrupt processing and transfers control to the interrupt-processing routine.
  - (g) When an interrupt source generated in step (a) is cleared by software in the user's interrupt processing routine, the CPU terminates the interrupt processing.

Figure 2.3-1 "Interrupt-processing Flowchart" outlines the interrupt operation for the MB89990 series of microcontrollers.



Figure 2.3-1 Interrupt-processing Flowchart

## 2.4 **I/O Ports**

- he MB89990 series of microcontrollers have three parallel ports and 22 pins. P00 to P07 and P30 to P37 serve as 8-bit I/O ports, P40 to P45 serve as 6-bit I/O ports.
- Port0 and Port3 are also used as the I/O pin for the resource.

## ■ List of port functions

Table 2.4-1 List of Port Functions

| Pin<br>name   | Input<br>type | Output<br>type         | Function                          | bit7  | bit6  | bit5  | bit4         | bit3  | bit2  | bit1  | bit0  |
|---------------|---------------|------------------------|-----------------------------------|-------|-------|-------|--------------|-------|-------|-------|-------|
| P00 to        | CMOS          | CMOS<br>push-<br>pull  | Parallel<br>port 00 to<br>07      | P07   | P06   | P05   | P04          | P03   | P02   | P01   | P00   |
| P07           |               |                        | External interrupt 2              | ĪNT27 | ĪNT26 | ĪNT25 | ĪNT24        | ĪNT23 | ĪNT22 | ĪNT21 | ĪNT20 |
| P30 to        | CMOS          | Cmos                   | Parallel<br>port 30 to<br>37      | P37   | P36   | P35   | P34          | P3    | P32   | P31   | P30   |
| P37           | Hysteresis    | push-<br>pull          | Timer,<br>External<br>interrupt 1 | ROC   | INT12 | INT11 | TO/<br>INT10 | EC    | _     | -     | _     |
| P30 to<br>P37 | CMOS          | N-ch<br>open-<br>drain | Parallel<br>port 40 to<br>45      | _     |       | P45   | P44          | P43   | P42   | P41   | P40   |

## ■ Register List

I/O port consists of the following registers.

|                            | < 8 bit> |     |                                       |                                        |
|----------------------------|----------|-----|---------------------------------------|----------------------------------------|
| Address: 0000н             | PDR0     | R/W | Port 00 to 07 data register           | Initial value = XXXXXXXX <sub>B</sub>  |
| Address: 0001 <sub>H</sub> | DDR0     | W   | Port 00 to 07 data direction register | Initial value = 00000000B              |
| Address: 000CH             | PDR3     | R/W | Port 30 to 37 data register           | Initial value = XXXXXXXXB              |
| Address: 000DH             | DDR3     | W   | Port 30 to 37 data direction register | Initial value = 00000000B              |
| Address: 000EH             | PDR4     | R/W | Port 40 to 47 data register           | Initial value = XX1111111 <sub>B</sub> |

## **■** Description of Functions

The function of each port is described below.

(1) P00 to P07: CMOS type I/O ports

(also used as resource input and output)

P30 to P37: CMOS type I/O ports

(also used as resource input and output)

## Switching input and output

• This port has a data-direction register (DDR) and a port-data register (PDR) for each bit. Input and output can be set independently for each bit. The pin with the DDR set to 1 is set to output, and the pin with the DDR set to 0 is set to input. When the resource output bit is enabled, these ports are set to output irrespective of the DDR setting conditions.

#### • Operation for output port (DDR = 1)

- The value written at the PDR is output to the pin when the DDR is set to 1. When the PDR is read, usually, the value of the pin is read instead of the contents of the output latch. However, when the Read Modify Write instruction is executed, the contents of the output latch are read irrespective of the DDR setting conditions. Therefore, the bit-processing instruction can be used even if input and output are mixed with each other. When data is written to the PDR, the written data is held in the output latch irrespective of the DDR setting conditions.
- Operation for input port (DDR = 0)
  - When used as the input port, the output impedance goes High. Therefore, when the PDR is read, the value of the pin is read.

#### Resource output operation

 When using as the resource output, setting is performed by the resource output enable bit. (See the description of each resource.) Since the resource output enable bit has priority in switching input and output, even if the DDR is set to 0, any bit is set as the resource output when output is enabled at each resource. Even if the output from each resource is enabled, the read parallel port is effective, so the resource output value can be checked.

#### Resource input operation

 The pin value at a port with the resource input function is always input for the resource input (irrespective of the setting of the DDR and resource). Set the DDR to input when using an external signal for the resource input.

## State when reset

 When reset, the DDR and the output enable bit for each resource are initialized to 0 and the output impedance goes High at all bits. When reset, the PDR is not defined. Therefore, set the value of the PDR before setting the DDR to output.

#### State when stop

• With the SPL bit of the standby-control register set to 1, in the stop mode, the output impedance goes High irrespective of the value of the DDR.

External interrupt enable Stop mode SPL = 1 To external interrupt Stop mode SPL = 1 To resource input Internal data bus Resource Resource output EN output **PDR** Pull-up resistor (option) PDR read PDR read (when Read Modify Write instruction executed) Output latch PDR write Pch **DDR** Pin DDR write Nch Stop mode SPL = 1

Figure 2.4-1 Ports 00 to 07 and 30 to 37

- (2) P40 to P45: N-ch open-drain-type output ports (also used as analog input)
- Operation for output port
  - The value written at the PDR is output to the pin. When the PDR is read in this port, the contents of the output latch is always read instead of the value of the pin.
- State when reset
  - The PDR is initialized to 1 at reset, so the output register is turned off at all bits.
- · State in stop mode
  - When the SPL bit of the standby-control register is set to 1, in the stop mode, the output impedance goes High irrespective of the value of the PDR.

Figure 2.4-2 Ports 40 to 45



# 2.5 8/16-bit Timer (Timer 1 and Timer 2)

- Three internal clock pulses and one external clock pulse can be selected.
- Operation in 8-bit 2-ch mode or 16-bit 1-ch mode can be selected.
- A square-wave output function is included.

## ■ Block Diagram

Figure 2.5-1 8/16-bit Timer Block Diagram



## ■ Register List



## **■** Description of Register Details

The detail of each register is described below.

## (1) Timer 1 control register (T1CR)



[Bit 7] T1IF: Interrupt request flag

(When write)

| 0 | Interrupt request flag clearing |
|---|---------------------------------|
| 1 | No operation                    |

## (When read)

| 0 | No interrupt request       |
|---|----------------------------|
| 1 | Interval interrupt request |

<sup>1</sup> is always read when the Read Modify Write instruction is executed.

[Bit 6] T1IE: Interrupt-enable bit

| 0 | Interrupt disabled |
|---|--------------------|
| 1 | Interrupt enabled  |

[Bit 5 and 4] T1OS1, T1OS0: Square-wave output control bit

| T10S1 | T10S0 |                                                          |
|-------|-------|----------------------------------------------------------|
| 0     | 0     | Makes square-wave output port (P43) general-purpose port |
| 0     | 1     | Holds data setting square-wave output to Low level       |
| 1     | 0     | Holds data setting square-wave output to High level      |
| 1     | 1     | Sets square-wave output to held value                    |

When the T1STR bit is 0, the square-wave output is set to the set value.

[Bit 3 and 2] T1CS1, T1CS0: Clock source select bit

| T1CS1 | T1CS0 | Clock cycle time selected at 4 MHz | Clock cycle time        |
|-------|-------|------------------------------------|-------------------------|
| 0     | 0     | 2.0 [μs]                           | × 2 instruction cycle   |
| 0     | 1     | 32.0 [μs]                          | ×32 instruction cycle   |
| 1     | 0     | 512 [μs]                           | × 512 instruction cycle |
| 1     | 1     | External clock                     |                         |

#### Note:

When using Timer 1 in the 8-bit mode, the clock source selection bits (T1CS1 and T1CS0) of the Timer 2 control register (T2CR) must be set to other than the 16-bit mode.

[Bit 1] T1STP: Timer-stop bit

| 0 | Counting continued without clearing counter |
|---|---------------------------------------------|
| 1 | Counting suspended                          |

## [Bit 0] T1STR: Timer-start bit)

| 0 | Terminates operation                |  |
|---|-------------------------------------|--|
| 1 | Clears counter and starts operation |  |

## (2) Timer 2 control register (T2CR)

Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 Address: 0018<sub>H</sub> T21F T21E T2CS1 T2CS0 T2STP T2STR (R/W) (R/W) (R/W) (R/W) (R/W) (R/W) (R/W) (R/W) Intilial value X00000X0<sub>B</sub>

[Bit 7] T2IF: Interrupt request flag bit

(When write)

| 0 | Interrupt request flag clearing |  |
|---|---------------------------------|--|
| 1 | No operation                    |  |

## (When read)

| 0 | No interrupt request       |
|---|----------------------------|
| 1 | Interval interrupt request |

<sup>1</sup> is always read when the Read Modify Write instruction is executed.

[Bit 6] T2IE: Interrupt-enable bit

| 0 | Interrupt disabled |
|---|--------------------|
| 1 | Interrupt enabled  |

[Bit 3 and 2]: T2CS1, T2CS0: Clock source select bit

| T2CS1 | T2CS0 | Clock cycle time selected at 4 MHz | Clock cycle time       |  |
|-------|-------|------------------------------------|------------------------|--|
| 0     | 0     | 2.0 [μs]                           | × 2 instruction cycle  |  |
| 0     | 1     | 32.0 [μs]                          | × 32 instruction cycle |  |
| 1     | 0     | 512 [μs]                           | ×512 instruction cycle |  |
| 1     | 1     | 16 bit mode                        |                        |  |

[Bit 1] T2STP: Timer stop bit

| 0 | Operation continued without clearing counter |  |
|---|----------------------------------------------|--|
| 1 | Count operation suspended                    |  |

[Bit 0] T2STR: Timer start bit

| 0 | Operation stopped                        |
|---|------------------------------------------|
| 1 | Operation started after clearing counter |

## (3) Timer 1 and 2 data registers (T1DR and T2DR)



Write data is the set interval times and read data is the counted times.

## **■** Description of Operation

## (1) 8-bit internal clock mode

In the 8-bit internal clock mode, three internal clock inputs can be selected by setting the clock source select bits (T1CS1 and T1CS0, T2CS1 and T2CS0) of the timer control registers (T1CR and T2CR). The timer data registers (T1DR and T2DR) serve as interval time setting registers.

To start the timer, set the interval time as the timer data registers, write 1 at the timer start bits (T1STR and T2STR) of the timer control registers to clear the counter to  $00_H$ , and load the values of the timer data registers into the compare latch. Then, counting starts.

When the values of the counter agree with those of the timer data registers, the interval interrupt request flags (T1IF and T2IF) are set to 1. At this time, the counter is cleared to  $00_H$ , the values of the timer data registers are reloaded into the compare latch, and counting is continued. If the interrupt enable bits (T1IE and T2IE) are set to 1, an interrupt request is output to the CPU. Assuming the set value of the timer data register is n and the selected clock is  $\phi$ , the interval time (T) can be calculated as follows.

 $T = \phi \times (n + 1) [\mu s]$ 

Figure 2.5-2 Description Diagram for Internal Clock Mode Operation



Figure 2.5-3 Flow Diagram for Timer Setting



#### (2) Initializing square-wave output

The square-wave output can be set to any value only when the timer stops (T1STR = 0 and T2STR = 0).

To set, proceed as follows:

- (a) Write the set values (01 and 10) at the initialize bits (T1OS1 and T1OS0, T2OS1 and T2OS2, respectively) of the square wave output.
- (b) Write 11 at the same bits. This initializes the square wave output to the set value. If the T1STR bit is set to 0, the square wave output of the pin is set to the set value during this write cycle.

Figure 2.5-4 Initialization of Equivalent Circuit



#### (3) 8-bit external clock mode

In the 8-bit external clock mode, the external clock input can be selected by setting the clock source select bits (T1CS1 and T1CS0) of the timer 1 control register (T1CR).

To start the timer, write 1 at the timer start bit (T1STR) of the T1CR to clear the counter. Then, counting starts.

When the value of the counter agrees with that of the timer data register setting, the interval interrupt request flag bit (T1IF) is set to 1. At this time, if an interrupt is enabled (T1IE = 1), an interrupt request is output to the CPU.

Figure 2.5-5 External Cock Mode Operation Description Diagram



#### (4) Precautions for use of timer stop bit

Since an input clock pulse is fixed to High level when the timer is stopped by the timer start bits, the count value differs depending on the state of the input clock pulse.

When writing 00 at the timer stop and timer start bits simultaneously after stopping the timer with the timer stop bit, the count may be incremented by 1. Therefore, if the timer is stopped by the timer stop bit, read the counter and then write 00 at the timer start bits (See Figure 2.5-6 "Operation Diagram when Timer Stop Bit is Used".).

When input clock is High

CK

CK'

TSTP

TSTR

TSTR'

Count value

Figure 2.5-6 Operation Diagram when Timer Stop Bit is Used

#### (5) 16-bit mode

In the 16-bit mode, each bit of the timer control registers is as shown below.

|                            | Bit 7        | Bit 6 | Bit 5 | Bit 4 | Bit 3 | Bit 2 | Bit 1  | Bit 0   |
|----------------------------|--------------|-------|-------|-------|-------|-------|--------|---------|
| Address: 0019 <sub>H</sub> | T1IF         | T1IE  | T10S1 | T10S0 | T1CS1 | T1CS0 | T1STP  | T1STR   |
| Address: 0018 <sub>H</sub> | T2IF         | T2IF  | _     | _     | TECS1 | TECS0 | T2STP  | T2STR   |
|                            |              |       |       |       |       |       |        |         |
|                            | No operation |       | Set t | to 00 | Set t | o 11  | No ope | eration |

In the 16-bit mode, write 11 at the T2CS1 and T2CS0 bits of the T2CR and set 00 at the T2OS1 and T2OS0 bits.

When in the 16-bit mode, the timer is controlled by the T1CR. The timer data registers T2DR and T1DR use the upper and lower bytes, respectively.

The clock source is selected by the T1CS1 and T1CS0 bits of the T1CR. To start the timer, write 1 at the T1STR bit of the T1CR to clear the counter.

If the value of the counter agrees with that of the timer data register, the T1IF bit is set to 1. At this time, an interrupt request is output to the CPU if the T1IE bit is 1.

#### Note:

To read the value of the counter in the 16-bit mode, always read the value twice to check that it is valid, and then use the data.

See the 8-bit operation diagram for 16-bit mode operation.

# 2.6 External Interrupt 1

- The edges of three external-interrupt sources (INT10 to INT12) can be detected to set the corresponding flag.
- . An interrupt can be generated at the same time the flag is set.
- The three interrupts can release the STOP or SLEEP mode.

## **■** Block diagram



## ■ Registers



## ■ Description of Registers

(1) External-interrupt control register 1 (EIC1)

The EIC1 controls interrupts by the INT10 and INT11 pins.

Bit 7 Bit 6 Bit 5 Bit 4 Bit 3 Bit 2 Bit 1 Bit 0 Address: 0023<sub>H</sub> EIR1 SL11 **SL10** EIE1 EIR0 SL01 **SL00** EIE0 (R/W) (R/W) (R/W) (R/W) (R/W) (R/W) (R/W) (R/W) Intilial value 00000000<sub>B</sub>

[Bit 7] EIR1: External-interrupt request flag

When the edge specified by the SL11 and SL10 bits is input to the INT11 pin, bit 7 is set to 1. When the EIE1 bit is 1, an interrupt request (IRQ1) is output if this bit is set.

The meaning of each bit to be read is as follows:

| 0 | Specified edge not input to INT11 pin               |  |
|---|-----------------------------------------------------|--|
| 1 | Specified edge input to INT11 pin (IRQ1 is output.) |  |

1 is always read when the Read Modify Write instruction is read.

The meaning of each bit to be written is as follows:

| 0 | This bit is cleared.                            |
|---|-------------------------------------------------|
| 1 | This bit does not change nor affect other bits. |

[Bit 6 and 5] SL11, SL10: Edge-polarity select bit

This bit is used to control the input edge polarity of the INT11 pin.

| SL11 | SL10 |                   |
|------|------|-------------------|
| 0    | 0    | No edge detection |
| 0    | 1    | Rising edge       |
| 1    | 0    | Falling edge      |
| 1    | 1    | Both-edge mode    |

[Bit 4] EIE1: Interrupt-enable bit

This bit is used to enable an external-interrupt request by the INT11 pin.

| 0 | Interrupt request disabled                |  |
|---|-------------------------------------------|--|
| 1 | Interrupt request enabled by EIR1 setting |  |

## [Bit 3] EIR0: External-interrupt request flag

When the edge specified by the SL01 and SL00 bits is input to the INT10 pin, bit 3 is set to 1. When the EIE0 is 1, an interrupt request (IRQ0) is output if this bit is set.

The meaning of each bit to be read is as follows:

| 0 | Specified edge not input to INT10 pin               |  |
|---|-----------------------------------------------------|--|
| 1 | Specified edge input to INT10 pin (IRQ0 is output.) |  |

1 is always read when the Read Modify Write instruction is read.

The meaning of each bit to be written is as follows:

| 0 | This bit is cleared.                            |
|---|-------------------------------------------------|
| 1 | This bit does not change nor affect other bits. |

[Bit 2 and 1] SL01, SL00: Edge-polarity select bit

This bit is used to control the input edge polarity of the INT10 pin.

| SL01 | SL00 |                   |
|------|------|-------------------|
| 0    | 0    | No edge detection |
| 0    | 1    | Rising edge       |
| 1    | 0    | Falling edge      |
| 1    | 1    | Both-edge mode    |

## [Bit 0] EIE0: Interrupt-enable bit

Bit 0 is used to enable an external-interrupt request by the INT10 pin.

| 0 | Interrupt request disabled                |
|---|-------------------------------------------|
| 1 | Interrupt request enabled by EIR0 setting |

## (2) External-interrupt control register 2 (EIC2)

The EIC2 controls an interrupt by the INT12 pins.

[Bit 3] EIR2: External-interrupt request flag

When the edge specified by the SL21 and SL20 bit is input to the INT12 pin, bit 3 is set to 1. When the EIE2 bit is 1, an interrupt request (IRQ2) is output if this bit is set.

The meaning of each bit to be read is as follows:

| 0 | Specified edge not input to INT12 pin               |
|---|-----------------------------------------------------|
| 1 | Specified edge input to INT12 pin (IRQ2 is output.) |

1 is always read when the Read Modify Write instruction is read.

The meaning of each bit to be written is as follows:

| 0 | This bit is cleared.                            |
|---|-------------------------------------------------|
| 1 | This bit does not change nor affect other bits. |

[Bit 2 and 1] SL21, SL20: Edge-polarity select bit

This bit is used to control the input edge polarity of the INT12 pin.

| SL21 | SL20 |                   |
|------|------|-------------------|
| 0    | 0    | No edge detection |
| 0    | 1    | Rising edge       |
| 1    | 0    | Falling edge      |
| 1    | 1    | Both-edge mode    |

[Bit 0] EIE2: Interrupt-enable bit

This bit is used to enable an external-interrupt request by the INT12 pin.

| 0 | Interrupt request disabled                   |
|---|----------------------------------------------|
| 1 | Interrupt request enabled by setting of EIR2 |

#### ■ Precautions for External-interrupt Circuit

- When enabling an interrupt after clearing reset, always clear the interrupt flag simultaneously. An interrupt request is output immediately when the interrupt flags (EIR2, EIR1, EIR0) are set to 1.
- When no edge detection is specified by the edge-polarity select bit, the current input is held before the internal edge detection block. If an edge is specified in this state, edge detection may be erroneous. Therefore, always clear the flag after an edge is specified.

# 2.7 External Interrupt 2 (Wake Up)

- Eight external interrupt input pins
- An interrupt request is output by Low-level input signals.
- Also usable as wake-up input

## **■** Block Diagram



## **■** Register List

This external interrupt 2 consists of external interrupt 2 control register (EIE2) and external interrupt 2 flag register (EIF2).



## ■ Description of Registers

The detail of each register is described below.

(1) External interrupt 2 control register (EIE2)

Bit 7 Bit 6 Bit 3 Bit 0 Bit 5 Bit 4 Bit 2 Bit 1 Address: 0032<sub>H</sub> **IE27 IE26** IE21 IE25 IE24 IE23 IE22 **IE20** (R/W) (R/W) (R/W) (R/W) (R/W) (R/W) (R/W) (R/W) Intilial value 0000000<sub>B</sub>

[Bit 7 to 0] IE27 to IE20: Operation-enable bit

These bits are used to operation-enable external interrupt of INT27 to INT20.

| 0 | External interrupt operation-disabled |
|---|---------------------------------------|
| 1 | External interrupt operation-enabled  |

(2) External interrupt 2 control register (EIF2)



Intilial value

[Bit 0] IF20: Low-level detect flag bit

This bit is used to detect LOW level of INT27 to INT20.

(When write)

| 0 | Clears flag for detecting LOW level |  |
|---|-------------------------------------|--|
| 1 | No operation                        |  |

(When read)

| 0 | No LOW level input       |
|---|--------------------------|
| 1 | LOW level input detected |

If any of the interrupt enable bits (IE27 to IE20) of the external interrupt 2 control register (EIE2) is 1, the Low-level detect flag bit (IF20) is set to 1 and an interrupt request is output to the CPU when a Low level is input to the port corresponding to this bit.

#### Note:

Unlike other resources, even if the external interrupt 2 circuit is disabled for an interrupt, it keeps generating interrupts until the interrupt source is cleared. Therefore, always clear the interrupt source (after disabling an interrupt).

# 2.8 Remote-control Carrier Frequency Generator

- This generator is a remote-control circuit for generating remote-control carrier frequencies.
- The 6-bit binary counter is built in.
- Four internal clock pulses can be selected to set a duty (H width) and cycle.

## ■ Block Diagram



CPU clock: Halved from source clock

## ■ Register List



## ■ Description of Registers

## (1) Remote-control register 1 (RCR1)

This register is used to select the reference clock and set the duty of remote-control carrier frequency.

|                            | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3                      | Bit 2 | Bit 1 | Bit 0 |
|----------------------------|-------|-------|-------|-------|----------------------------|-------|-------|-------|
| Address: 0014 <sub>H</sub> | RCK1  | RCK0  | HSC5  | HSC4  | HSC3                       | HSC2  | HSC1  | HSC0  |
|                            | (R/W) | (R/W) | (R/W) | (R/W) | (R/W)                      | (R/W) | (R/W) | (R/W) |
|                            |       |       |       |       | value<br>0000 <sub>B</sub> |       |       |       |

[Bits 7 and 6] RCK1 and RCK0: Bits for selecting the reference clock for remote-control carrier frequency

These bits are used to select the reference clock for the remote-control carrier frequency.

| RCR1 | RCR0             | Reference clock at 4 MHz |  |  |  |  |
|------|------------------|--------------------------|--|--|--|--|
| 0    | 0 0 2/f (0.5 μs) |                          |  |  |  |  |
| 0    | 1                | 4/f (1.0 μs)             |  |  |  |  |
| 1    | 0                | 32/f (8.0 μs)            |  |  |  |  |
| 1    | 1                | 128/f (32.0 μs)          |  |  |  |  |

f = source clock frequency

[Bits 5 to 0] HSC5 to HSC0: Bits for setting duty of remote-control carrier frequency

These bits are used for the 6-bit compare register to set the duty of the remote-control carrier frequency.

To set the duty of the remote-control carrier frequency, set the value subtracted 1 from the value calculated from the clock in binary at these bits. For example, to set a duty of 26 ms, select resource clock = 4/f and set 011001 (1/26 oscillation) at these 6 bits. This enables the selection of any duty.

## (2) Remote-control register 2 (RCR2)

This register is used to enable the output and set the cycle of remote-control carrier frequency.

|                            | Bit 7 | Bit 6 | Bit 5 | Bit 4 | Bit 3                      | Bit 2 | Bit 1 | Bit 0 |
|----------------------------|-------|-------|-------|-------|----------------------------|-------|-------|-------|
| Address: 0015 <sub>H</sub> | RCEN  | _     | SCL5  | SCL4  | SCL3                       | SCL2  | SCL1  | SCL0  |
|                            | (R/W) |       | (R/W) | (R/W) | (R/W)                      | (R/W) | (R/W) | (R/W) |
|                            |       |       |       |       | value<br>0000 <sub>B</sub> |       |       |       |

[Bit 7] RCEN: Bit for enabling output of remote-control carrier frequency

This bit is used to enable the output of remote-control carrier frequency to the P37/BZ/RCO pin. Setting this bit to 0 enables clearing of the 6-bit counter.

[Bits 5 to 0] SCL5 to SCL0: Bits for setting cycle of remote-control carrier frequency

These bits are used for the 6-bit compare register to set the cycle of the remote-control carrier frequency. To set the cycle of the remote-control carrier frequency, set the value subtracted 1 from the value calculated from the clock source in binary at these bits. For example, to set a cycle of 60 ms, select reference clock = 4/f and set 111011 (1/60 oscillation) at these 6 bits. This enables selection of a cycle of  $60 \, \mu s$ .

## **■** Description of Operation

Remote-control registers 1 and 2 (RCR1 and RCR2) control a 6-bit counter to output the remote-control carrier frequency to the P37/BZ/RCO pin.

A usage example is given below.

<Example>

Cycle: about 20 kHz

Duty: 1/3

Reference clock: 4/f (f = source clock)



#### Note:

To set the duty and cycle, the cycle set value must always be greater than the set duty value.

## 2.9 Time-base Timer

- This timer has a 20-bit binary counter and uses a clock pulse with 1/2 oscillation of the source clock.
- · Four interval times can be selected.
- This function cannot be used in the STOP state.

## **■** Block Diagram



\*TBTC is a clock pulse with 1/2 oscillation of the souce clock.

## ■ Register List

The time-base timer has time-base timer control register (TBCR).



## **■** Description of Registers

The detail of time-base timer control register (TBCR) is described below.

(1) Timer-base timer control register (TBCR)



[Bit 4] TBIE: Interval-timer interrupt enable bit

This bit is used to enable an interrupt by the interval timer.

| 0 | Interval interrupt disabled |
|---|-----------------------------|
| 1 | Interval interrupt enabled  |

[Bit 3] TBOF: Interval timer overflow bit

When writing, this bit is used to clear the interval timer overflow flag.

| 0 | Interval timer overflow flag cleared |  |
|---|--------------------------------------|--|
| 1 | No operation                         |  |

When reading, this bit indicates that an interval timer overflow has occurred.

| 0 | Interval timer overflow not occurred |
|---|--------------------------------------|
| 1 | Interval timer overflow occurred     |

1 is read when the Read Modify Write instruction is read. If the TBIF bit is set to 1 when the TBIE bit is 1, an interrupt request is output. This bit is cleared upon reset.

[Bit 2] TBR: Time-base timer clear bit

This bit is used to clear time-base timer.

| 0 | Time-base timer cleared |
|---|-------------------------|
| 1 | No operation            |

1 is always read when this bit is read.

[Bit 1 and 0] TBC1, TBC0: Interval time specification bit

These bits are used to specify interval timer cycle.

| TBC1 | TBC0 | Interval time      | Value at f = 4 MHz |
|------|------|--------------------|--------------------|
| 0    | 0    | 2 <sup>13</sup> /f | 2.05 [ms]          |
| 0    | 1    | 2 <sup>15</sup> /f | 8.19 [ms]          |
| 1    | 0    | 2 <sup>18</sup> /f | 65.54 [ms]         |
| 1    | 1    | 2 <sup>21</sup> /f | 524.29 [ms]        |

f = clock frequency

# 2.10 Watchdog Timer Reset

• The watchdog timer is reset by using the time-base timer output as a clock.

## **■** Block Diagram



## ■ Registers

The watchdog timer reset has watchdog timer control register (WDTE).



## ■ Description of Register

The detail of the watchdog timer control register (WDTE) is described below.

(1) Watchdog timer control register (WDTE)



[Bits 3 to 0] WTE3 to WTE0: Watchdog timer control bit

These bits are used to control the watchdog timer.

First write after reset

| 0101                 | Watchdog timer started |
|----------------------|------------------------|
| Other than the above | No operation           |

Second and later write

| 0101                 | Watchdog timer counter cleared |
|----------------------|--------------------------------|
| Other than the above | No operation                   |

The watchdog timer can be stopped only by reset. 1111 is read when these bit are read.

## **■** Description of Operation

## (1) Starting watchdog timer

The watchdog timer starts when 0101 is written at the watchdog timer control bits.

## (2) Clearing watchdog timer

When 0101 is written at the watchdog timer control bits after start, the watchdog timer is cleared. The counter of the watchdog timer is cleared when changing to the standby mode (STOP, SLEEP).

## (3) Watchdog timer reset

If the watchdog timer is not cleared within the time given in the table below, a watchdog timer reset occurs to reset the chip internally.

|              | Time-base timer cycle $2^{21}$ /f |   |  |
|--------------|-----------------------------------|---|--|
| Minimum time | Approx. 524 ms                    | 1 |  |
| Maximum time | Approx. 1049 ms                   | 1 |  |

f:4MHz

#### (4) Stopping watchdog timer

Once started, the watchdog timer will not stop until a reset occurs.

# **CHAPTER 3 OPERATION**

## The operation of MB89990 is described below.

- 3.1 Clock Pulse Generator
- 3.2 Reset
- 3.3 Interrupt
- 3.4 Low-power Consumption Modes
- 3.5 Pin States for Sleep, Stop and Reset

## 3.1 Clock Pulse Generator

This section describes the clock pulse generator.

## **■ Clock Pulse Generator**

The MB89990 series of microcontrollers incorporate the system clock pulse generator. The ceramic or crystal oscillator, or CR is connected to the X0 and X1 pins to generate clock pulses. Clock pulses can also be supplied internally by inputting externally-generated clock pulses to the X0 pin. The X1 pin should be kept open.

MB89990
X0
X1
OPEN X1

MB89990
X0
X1

MB89990
X1

Figure 3.1-1 Clock Pulse Generator

# 3.2 Reset

This section describes reset.

## ■ Reset

The detail of reset operation and reset sources are described below.

## 3.2.1 Reset Operation

## The reset operation is described below.

## ■ Reset Operation

When reset conditions occur, the MB89990 series of microcontrollers suspend the currently-executing instruction to enter the reset state. The contents written at the RAM do not change before and after reset. However, if a reset occurs during writing of 16-bit long data, data is written to the upper bytes and may not be written to lower bytes. If a reset occurs around write timing, the contents of the addresses being written are not assured.

When the reset conditions are cleared, the MB89990 series of microcontrollers are released from the reset state and start operation after fetching the mode data from address  ${\tt FFFD}_{\sf H}$ , the upper bytes of the reset vectors from address  ${\tt FFFE}_{\sf H}$ , and the lower bytes from address  ${\tt FFFF}_{\sf H}$ , in that order. Figure 3.2-1 "Outline of Reset Operation" shows the flowchart for the reset operation.

Fetch mode data from address FFFDH.

Fetch reset vectors from addresses FFFEH and FFFFH.

Fetch instruction codes from reset vectors and execute the instruction.

Execute the next instruction.

Figure 3.2-1 Outline of Reset Operation

Figure 3.2-2 "Reset Vector Structure" indicates the structure of data to be stored in addresses FFFDH, FFFEH, and FFFFH.

FFFFH Lower 8 bits of reset vector

Upper 8 bits of reset vector

Upper 8 bits of reset vector

FFFDH Mode data

Reserved; always set 0.

Figure 3.2-2 Reset Vector Structure

## 3.2.2 Reset Source

## The reset sources are described below.

#### ■ Reset Source

The MB89990 series of microcontrollers have the following reset source.

(1) External pin

A Low level is input to the RST pin.

(2) Specification by software

0 is written at the  $\overline{\mathsf{RST}}$  bit of the standby-control register.

(3) Power-on

When the power is turned on when the power-on reset option is selected.

(4) Watchdog function

The watchdog function is enabled by the watchdog-control register and reaccess to this register is not obtained within the specified time.

When the stop mode is cleared or when the power-on reset (option selected) is operated, is started after elapse of the oscillation stabilization time.

## 3.3 Interrupt

## This section describes interrupt.

#### ■ Interrupt

If the interrupt controller and CPU are ready to accept interrupts when an interrupt request is output from the internal resources or by an external-interrupt input, the CPU temporarily suspends the currently-executing instruction and executes the interrupt-processing program. Figure 3.3-1 "Interrupt-processing Flowchart" shows the interrupt-processing flowchart.



Figure 3.3-1 Interrupt-processing Flowchart

All interrupts are disabled after a reset is cleared. Therefore, initialize interrupts in the main program (1). Each resource generating interrupts and the interrupt-level-setting registers (ILR1 to ILR3) in the interrupt controller corresponding to these interrupts are to be initialized. The levels of all interrupts can be set by the interrupt-level-setting registers (ILR1 to ILR3) in the interrupt controller. The interrupt level can be set from 1 to 3, where 1 indicates the highest level, and 2 the second highest level. Level 3 indicates that no interrupt occurs. The interrupt request of level 3 cannot be accepted. After initializing the registers, the main program executes various controls (2). Interrupts are generated from the resources (3). The highest-priority interrupt requests are identified from those occurring at the same time by the interrupt controller and are transferred to the CPU. The CPU then checks the current interrupt level and the status of the I-flag (4), and starts the interrupt processing.

The CPU performs the interrupt processing to save the contents of the current PC and PS in the stack (5) and fetches the entry addresses of the interrupt program from the interrupt vectors. After updating the IL value in the PS to the required one, the CPU starts executing the interrupt-processing routine.

Clear the interrupt sources (6) and process the interrupts in the user's interrupt-processing routine. Finally, restore the PC and PS values saved by the RETI instruction in the stack (8) to return to the interrupted instruction.

#### Note:

Unlike the F<sup>2</sup>MC-8 family, A and T are not saved in the stack at the interrupt time.

Table 3.3-1 "Interrupt Sources and Interrupt Vectors" lists the relationships between each interrupt source and interrupt vector.

**Table 3.3-1 Interrupt Sources and Interrupt Vectors** 

| Interrupt source                      | Upper vector address | Lower vector address |
|---------------------------------------|----------------------|----------------------|
| IRQ0 (External interrupt)             | FFFA <sub>H</sub>    | FFFB <sub>H</sub>    |
| IRQ1 (External interrupt)             | FFF8 <sub>H</sub>    | FFF9 <sub>H</sub>    |
| IRQ2 (External interrupt)             | FFF6 <sub>H</sub>    | FFF7 <sub>H</sub>    |
| IRQ3 (8/16-bit timer counter timer 1) | FFF4 <sub>H</sub>    | FFF5 <sub>H</sub>    |
| IRQ4 (8/16-bit timer counter timer 2) | FFF2 <sub>H</sub>    | FFE3 <sub>H</sub>    |
| IRQ5 (Unused)                         | FFF0 <sub>H</sub>    | FFF1 <sub>H</sub>    |
| IRQ6 (Unused)                         | FFEE <sub>H</sub>    | FFEF <sub>H</sub>    |
| IRQ7 (Interval timer)                 | FFEC <sub>H</sub>    | FFED <sub>H</sub>    |
| IRQ8 (Unused)                         | FFEA <sub>H</sub>    | FFEB <sub>H</sub>    |
| IRQ9 (Unused)                         | FFE8 <sub>H</sub>    | FFE9 <sub>H</sub>    |
| IRQA (Wake-up)                        | FFE6 <sub>H</sub>    | FFE7 <sub>H</sub>    |

# 3.4 Low-power Consumption Modes

This section describes low-power consumption modes.

## ■ Low-power Consumption Modes

The MB89990 series of microcontrollers have two standby modes: sleep and stop to reduce the power consumption. Writing to the standby control register (STBC) switches to these two standby modes. See 2.1.4 for setting and releasing each mode.

The MB89990 series of microcontrollers have a double clock module, and the low-power consumption modes vary with the main clock and subclock modes. Whether or not an oscillation stabilization period is required at release from each low-power consumption mode depends on the mask option of the power-on reset (See 2.1.4).

Table 3.4-1 Low-power Consumption Mode at Each Clock Mode

| Function          |                    | Main mode |         |         |  |
|-------------------|--------------------|-----------|---------|---------|--|
|                   |                    | RUN       | SLEEP   | STOP    |  |
| Clock oscillation |                    | Operate   | Operate | Stop    |  |
|                   | Instruction        | Operate   | Stop    | Stop    |  |
| CPU               | ROM                | Operate   | Hold    | Hold    |  |
|                   | RAM                | Operate   |         |         |  |
|                   | I/O                | Operate   | Hold    | Hold    |  |
|                   | Time-base timer    | Operate   | Operate | Stop    |  |
|                   | 16-bit timer       | Operate   | Operate | Stop    |  |
| Resource          | 8-bit SIO          | Operate   | Operate | Stop    |  |
|                   | ADC                | Operate   | Operate | Stop    |  |
|                   | External interrupt | Operate   | Operate | Operate |  |
|                   | Buzzer output      | Operate   | Operate | Stop    |  |
|                   | Watchdog timer     | Operate   | Stop    | Stop    |  |

# 3.5 Pin States for Sleep, Stop and Reset

This section describes the pin states for sleep, stop, and reset.

## ■ Pin States for Sleep, Stop, and Reset

The state of each pin of the MB89990 series of microcontrollers at sleep, stop, and reset is as follows:

(1) Sleep

The pin state immediately before the sleep state is held.

(2) Stop

The pin state immediately before the stop state is held when the stop mode is started and bit 5 of the standby-control register (STBC) is set to 0; the impedance of the output and input/output pins goes High when the bit is set to 1.

(3) Reset

The impedance of all I/O and resource pins (excluding pins for pull-up option) goes High.

Table 3.5-1 Pin State of MB89990

| Pin name                  | Normal                | Sleep                 | Stop<br>SPL = 0 | Stop<br>SPL = 1     | Reset                 |
|---------------------------|-----------------------|-----------------------|-----------------|---------------------|-----------------------|
| P00/INT20 to<br>P07/INT27 | Port/resource<br>I/O  | Previous state        | Previous state  | High impedance*2,*3 | High<br>impedance     |
| X0                        | Input for ocillation  | Input for ocillation  | High impedance  | High impedance      | Input for ocillation  |
| X1                        | Output for ocillation | Output for ocillation | H output        | H output            | Output for ocillation |
| TEST                      | Test input            | Test input            | Test input      | Test input          | Test input            |
| RST                       | Reset input           | Reset input           | Reset input     | Reset input         | Reset input*1         |
| P30 to<br>P37/RCO         | Port/resource<br>I/O  | Previous state        | Previous state  | High impedance*2,*3 | High<br>impedance     |
| P40 to P45                | Port                  | Previous state        | Previous state  | High impedance*3    | High<br>impedance     |

<sup>\*1</sup> Reset pin is output in some option setting.

<sup>\*2</sup> The internal input level is fixed for port and resource inputs to prevent leakage due to open input. However, when external interrupt is enabled, only input is allowed for P00 to P07 and P34 to P36.

<sup>\*3</sup> Pins with the pull-up option provided by selecting the mask option are the pull-up state.

## **CHAPTER 3 OPERATION**

## **CHAPTER 4 INSTRUCTIONS**

#### This chapter describes instructions.

- 4.1 Transfer Instructions
- 4.2 Operation Instruction
- 4.3 Branch Instructions
- 4.4 Other Instructions
- 4.5 F<sup>2</sup>MC-8L Family Instruction Map

## 4.1 Transfer Instructions

#### This section describes the transfer instructions.

#### **■** Transfer Instructions

| Mnemonic         | ~   | # | Operation                                           | TL      | TH   | АН      | NZVC | OP code  |
|------------------|-----|---|-----------------------------------------------------|---------|------|---------|------|----------|
| MOV dir,A        | 3   | 2 | (dir) ← (A)                                         | _       | _    | -       |      | 45       |
| MOV @IX +off,A   | 4   | 2 | $((IX) + off) \leftarrow (A)$                       | _       | _    | _       |      | 46       |
| MOV ext,A        | 4   | 3 | (ext) ← (A)                                         | _       | _    | _       |      | 61       |
| MOV @EP,A        | 3   | 1 | ( (EP) ) ← (A)                                      | _       | _    | _       |      | 47       |
| MOV Ri,A         | 3   | 1 | (Ri) ← (A)                                          | _       | _    | _       |      | 48 to 4F |
| MOV A,#d8        | 2   | 2 | (A) ← d8                                            | AL      | _    | _       | ++   | 04       |
| MOV A,dir        | 3   | 2 | (A) ← (dir)                                         | AL      | _    | _       | ++   | 05       |
| MOV A,@IX +off   | 4   | 2 | $(A) \leftarrow ((IX) + off)$                       | AL      | _    | _       | ++   | 06       |
| MOV A,ext        | 4   | 3 | (A) ← (ext)                                         | AL      | _    | _       | ++   | 60       |
| MOV A,@A         | 3   | 1 | $(A) \leftarrow (A)$                                | AL      | _    | _       | ++   | 92       |
| MOV A,@EP        | 3   | i | (A) ← ( (EP) )                                      | AL      | _    | _       | ++   | 07       |
| MOV A,Ri         | 3   | i | (A) ← ((Li / )<br>(A) ← (Ri)                        | AL      | _    | _       | ++   | 08 to 0F |
| MOV dir,#d8      | 4   | 3 | $(dir) \leftarrow d8$                               | \       |      | _       | TT   | 85       |
| MOV @IX +off,#d8 | 5   | 3 |                                                     | _       | _    | _       |      |          |
| MOV @FP,#d8      | 4   | 2 | ((IX) +off) ← d8                                    |         |      |         |      | 86       |
|                  | 4   | 2 | ((EP)) ← d8                                         | _       | _    | _       |      | 87       |
| MOV Ri,#d8       | 1 - |   | (Ri) ← d8                                           | _       | _    | _       |      | 88 to 8F |
| MOVW dir,A       | 4   | 2 | $(dir) \leftarrow (AH), (dir + 1) \leftarrow (AL)$  | _       | _    | _       |      | D5       |
| MOVW @IX +off,A  | 5   | 2 | $((IX) + off) \leftarrow (AH),$                     | _       | _    | _       |      | D6       |
| 140000           | _   |   | $((IX) + off + 1) \leftarrow (AL)$                  |         |      |         |      |          |
| MOVW ext,A       | 5   | 3 | $(ext) \leftarrow (AH), (ext+1) \leftarrow (AL)$    | _       | _    | _       |      | D4       |
| MOVW @EP,A       | 4   | 1 | $((EP)) \leftarrow (AH), ((EP)+1) \leftarrow (AL)$  | _       | _    | _       |      | D7       |
| MOVW EP,A        | 2   | 1 | (EP) ← (A)                                          | _       | _    | _       |      | E3       |
| MOVW A,#d16      | 3   | 3 | (A) ← d16                                           | AL      | AH   | dΗ      | ++   | E4       |
| MOVW A,dir       | 4   | 2 | (AH) ← (dir), (AL) ← (dir + 1)                      | AL      | AH   | dΗ      | ++   | C5       |
| MOVW A,@IX +off  | 5   | 2 | $(AH) \leftarrow ((IX) + off),$                     | AL      | AH   | dΗ      | ++   | C6       |
|                  |     |   | (AL) ← ( (IX) +off + 1)                             |         |      |         |      |          |
| MOVW A,ext       | 5   | 3 | $(AH) \leftarrow (ext), (AL) \leftarrow (ext+1)$    | AL      | AH   | dΗ      | ++   | C4       |
| MOVW A,@A        | 4   | 1 | $(AH) \leftarrow ((A)), (AL) \leftarrow ((A)) + 1)$ | AL      | AH   | dΗ      | ++   | 93       |
| MOVW A,@EP       | 4   | 1 | (AH)←((EP)),(AL)←((EP)+1)                           | AL      | AH   | dΗ      | ++   | C7       |
| MOVW A,EP        | 2   | 1 | (A) ← (EP)                                          | _       | _    | dΗ      |      | F3       |
| MOVW EP,#d16     | 3   | 3 | (EP) ← d16                                          | _       | _    | _       |      | E7       |
| MOVW IX,A        | 2   | 1 | (IX) ← (A)                                          | _       | _    | _       |      | E2       |
| MOVW A,IX        | 2   | 1 | $(A) \leftarrow (X)$                                | _       | _    | dΗ      |      | F2       |
| MOVW SP,A        | 2   | 1 | (SP) ← (Á)                                          | _       | _    | _       |      | E1       |
| MOVW A,SP        | 2   | 1 | (A) ← (SP)                                          | _       | _    | dH      |      | F1       |
| MOV @A,T         | 3   | 1 | ((A)) ← (T)                                         | _       | _    | _       |      | 82       |
| MOVW @A,T        | 4   | 1 | $((A)) \leftarrow (TH), ((A)+1) \leftarrow (TL)$    | _       | _    | _       |      | 83       |
| MOVW IX,#d16     | 3   | 3 | (IX) ← d16                                          | _       | _    | _       |      | E6       |
| MOVW A,PS        | 2   | 1 | (A) ← (PS)                                          | _       | _    | dH      |      | 70       |
| MOVW PS,A        | 2   | 1 | (PS) ← (A)                                          | _       | _    | _       | ++++ | 70       |
| MOVW SP,#d16     | 3   | 3 | (SP) ← d16                                          | _       | _    | _       |      | E5       |
| SWAP             | 2   | 1 | (AH) ← (AL)                                         |         | _    | AL      |      | 10       |
| SETB dir: b      | 4   | 2 | (dir): b ← 1                                        |         |      | \       |      | A8 to AF |
| CLRB dir: b      | 4   | 2 | (dir): b ← 0                                        | _       |      | _       |      |          |
| XCH A,T          | 2   | 1 |                                                     | _<br>^I | _    | _       |      | A0 to A7 |
|                  |     |   | $(AL) \leftrightarrow (TL)$                         | AL      | Λ LI | _<br>신니 |      | 42       |
| XCHW A,T         | 3   | 1 | $(A) \longleftrightarrow (T)$                       | AL      | АН   | dH      |      | 43       |
| XCHW A,EP        | 3   | 1 | (A) ← (EP)                                          | _       | _    | dH      |      | F7       |
| XCHW A,IX        | 3   | 1 | $(A) \longleftrightarrow (IX)$                      | _       | _    | dH      |      | F6       |
| XCHW A,SP        | 3   | 1 | (A) ← (SP)                                          | _       | _    | dH      |      | F5       |
| MOVW A,PC        | 2   | 1 | (A) ← (PC)                                          | _       | _    | dH      |      | F0       |

#### Notes

- 1. During byte transfer to A, T <-- A is restricted to low bytes.
- 2. Operands in more than one operand instruction must be stored in the order in which their mnemonics are written. (Reverse arrangement of  $F^2MC-8$  family)

## 4.2 Operation Instruction

This section describes the operation instructions.

#### **■** Operation Instructions

| Mnemonic        | ~  | # | Operation                                      | TL | TH | AH | NZVC  | OP code  |
|-----------------|----|---|------------------------------------------------|----|----|----|-------|----------|
| ADDC A,Ri       | 3  | 1 | (A) ← (A) + (Ri) + C                           | _  | _  | _  | ++++  | 28 to 2F |
| ADDC A,#d8      | 2  | 2 | (A) ← (A) + d8 + C                             | _  | _  | _  | ++++  | 24       |
| ADDC A,dir      | 3  | 2 | (A) ← (A) + (dir) + C                          | _  | _  | _  | ++++  | 25       |
| ADDC A,@IX +off | 4  | 2 | $(A) \leftarrow (A) + ((IX) + off) + C$        | _  | _  | _  | ++++  | 26       |
| ADDC A,@EP      | 3  | 1 | (A) ← (A) + ( (EP) ) + C                       | _  | _  | _  | ++++  | 27       |
| ADDCW A         | 3  | 1 | (A) ← (A) + (T) + C                            | _  | _  | dH | ++++  | 23       |
| ADDC A          | 2  | 1 | (AL) ← (AL) + (TL) + C                         | _  | _  | _  | ++++  | 22       |
| SUBC A,Ri       | 3  | 1 | $(A) \leftarrow (A) - (Ri) - C$                | _  | _  | _  | ++++  | 38 to 3F |
| SUBC A,#d8      | 2  | 2 | $(A) \leftarrow (A) - d8 - C$                  | _  | _  | _  | ++++  | 34       |
| SUBC A,dir      | 3  | 2 | $(A) \leftarrow (A) - (dir) - C$               | _  | _  | _  | ++++  | 35       |
| SUBC A,@IX +off | 4  | 2 | $(A) \leftarrow (A) - ((IX) + off) - C$        | _  | _  | _  | ++++  | 36       |
| SUBC A,@EP      | 3  | 1 | (A) ← (A) – ( (EP) ) – C                       | _  | _  | _  | ++++  | 37       |
| SUBCW A         | 3  | 1 | $(A) \leftarrow (T) - (A) - C$                 | _  | _  | dH | ++++  | 33       |
| SUBC A          | 2  | 1 | (AL) ← (TL) − (AL) − C                         | _  | _  | _  | ++++  | 32       |
| INC Ri          | 4  | 1 | (Ri) ← (Ri) + 1                                | _  | _  | _  | +++-  | C8 to CF |
| INCW EP         | 3  | 1 | (EP) ← (EP) + 1                                | _  | _  | _  |       | C3       |
| INCW IX         | 3  | 1 | (IX) ← (IX) + 1                                | _  | _  | _  |       | C2       |
| INCW A          | 3  | 1 | (A) ← (A) + 1                                  | _  | _  | dH | ++    | C0       |
| DEC Ri          | 4  | 1 | (Ri) ← (Ri) – 1                                | _  | _  | _  | +++-  | D8 toDF  |
| DECW EP         | 3  | 1 | (EP) ← (EP) – 1                                | _  | _  | _  |       | D3       |
| DECW IX         | 3  | 1 | (IX) ← (IX) − 1                                | _  | _  | _  |       | D2       |
| DECW A          | 3  | 1 | $(A) \leftarrow (A) - 1$                       | _  | _  | dH | ++    | D0       |
| MULU A          | 19 | 1 | $(A) \leftarrow (AL) \times (TL)$              | _  | _  | dH |       | 01       |
| DIVU A          | 21 | 1 | $(A) \leftarrow (T) / (AL), MOD$ (T)           | dL | 00 | 00 |       | 11       |
| ANDW A          | 3  | 1 | $(A) \leftarrow (A) \land (T)$                 | _  | _  | dH | ++R-  | 63       |
| ORW A           | 3  | 1 | $(A) \leftarrow (A) \lor (T)$                  | _  | _  | dH | ++R-  | 73       |
| XORW A          | 3  | 1 | $(A) \leftarrow (A) \forall (T)$               | _  | _  | dH | ++R-  | 53       |
| CMP A           | 2  | 1 | (TL) – (AL)                                    | _  | _  | _  | ++++  | 12       |
| CMPW A          | 3  | 1 | (T) – (A)                                      | _  | _  | _  | ++++  | 13       |
| RORC A          | 2  | 1 |                                                | _  | _  | _  | ++-+  | 03       |
|                 | _  |   | $\rightarrow C \rightarrow A$                  |    |    |    | ' ' ' |          |
| ROLC A          | 2  | 1 |                                                | _  | _  | _  | ++-+  | 02       |
| OMD 4 # 10      |    |   |                                                |    |    |    |       | , ,      |
| CMP A,#d8       | 2  | 2 | (A) -d8                                        | _  | _  | _  | ++++  | 14       |
| CMP A,dir       | 3  | 2 | (A) – (dir)                                    | _  | _  | _  | ++++  | 15       |
| CMP A,@EP       | 3  | 1 | (A) – ( (EP) )                                 | _  | _  | _  | ++++  | 17       |
| CMP A,@IX +off  | 4  | 2 | (A) - ((IX) + off)                             | _  | _  | _  | ++++  | 16       |
| CMP A,Ri        | 3  | 1 | (A) – (Ri)                                     | _  | _  | _  | ++++  | 18 to 1F |
| DAA             | 2  | 1 | Decimal adjust foraddition                     | _  | _  | _  | ++++  | 84       |
| DAS             | 2  | 1 | Decimal adjust forsubtraction                  | _  | _  | _  | ++++  | 94       |
| XOR A           | 2  | 1 | (A) ← (AL) ∀ (TL)                              | _  | _  | _  | ++R-  | 52       |
| XOR A,#d8       | 2  | 2 | (A) ← (AL) ∀ d8                                | _  | _  | _  | ++R-  | 54       |
| XOR A,dir       | 3  | 2 | $(A) \leftarrow (AL) \ \forall \ (dir)$        | _  | _  | _  | ++R-  | 55       |
| XOR A,@EP       | 3  | 1 | (A) ← (AL) ∀ ( (ÉP) )                          | _  | _  | _  | ++R-  | 57       |
| XOR A,@IX +off  | 4  | 2 | $(A) \leftarrow (AL) \ \forall \ ((IX) + off)$ | _  | _  | _  | ++R-  | 56       |
| XOR A,Ri        | 3  | 1 | $(A) \leftarrow (AL) \forall (Ri)$             | _  | –  | _  | ++R-  | 58 to 5F |

#### 4.2 Operation Instruction

| Mnemonic         | ~ | # | Operation                                | TL | TH | AH | NZVC    | OP code  |
|------------------|---|---|------------------------------------------|----|----|----|---------|----------|
| AND A            | 2 | 1 | (A) ← (AL) ∧ (TL)                        | _  | _  | 1  | ++R-    | 62       |
| AND A,#d8        | 2 | 2 | $(A) \leftarrow (AL) \wedge d8$          | –  | _  | _  | + + R - | 64       |
| AND A,dir        | 3 | 2 | $(A) \leftarrow (AL) \land (dir)$        | –  | _  | _  | + + R - | 65       |
| AND A,@EP        | 3 | 1 | (A) ← (AL) ∧ ( (ÉP) )                    | –  | _  | _  | + + R – | 67       |
| AND A,@IX +off   | 4 | 2 | $(A) \leftarrow (AL) \land ((IX) + off)$ | –  | _  | _  | + + R – | 66       |
| AND A,Ri         | 3 | 1 | $(A) \leftarrow (AL) \land (Ri)$         | –  | _  | _  | + + R – | 68 to 6F |
| OR A             | 2 | 1 | $(A) \leftarrow (AL) \lor (TL)$          | -  | _  | _  | + + R – | 72       |
| OR A,#d8         | 2 | 2 | $(A) \leftarrow (AL) \lor d8$            | –  | _  | _  | + + R – | 74       |
| OR A,dir         | 3 | 2 | $(A) \leftarrow (AL) \lor (dir)$         | –  | _  | _  | + + R – | 75       |
| OR A,@EP         | 3 | 1 | $(A) \leftarrow (AL) \lor ((EP))$        | -  | _  | _  | + + R – | 77       |
| OR A,@IX +off    | 4 | 2 | $(A) \leftarrow (AL) \lor ((IX) + off)$  | -  | _  | _  | + + R – | 76       |
| OR A,Ri          | 3 | 1 | (A) ← (AL) ∨ (Ri)                        | -  | _  | _  | + + R – | 78 to 7F |
| CMP dir,#d8      | 5 | 3 | (dir) – d8                               | -  | _  | _  | ++++    | 95       |
| CMP @EP,#d8      | 4 | 2 | ( (EP) ) – d8                            | -  | _  | _  | ++++    | 97       |
| CMP @IX +off,#d8 | 5 | 3 | ((IX) + off) - d8                        | -  | _  | _  | ++++    | 96       |
| CMP Ri,#d8       | 4 | 2 | (Ri) – d8                                | -  | _  | _  | ++++    | 98 to 9F |
| INCW SP          | 3 | 1 | (SP) ← (SP) + 1                          | -  | _  | _  |         | C1       |
| DECW SP          | 3 | 1 | (SP) ← (SP) – 1                          | -  | _  | _  |         | D1       |

## 4.3 Branch Instructions

#### This section describes the branch instructions.

#### **■** Branch Instructions

| Mnemonic       | ~ | # | Operation                                      | TL | TH | АН | NZVC    | OP code  |
|----------------|---|---|------------------------------------------------|----|----|----|---------|----------|
| BZ/BEQ rel     | 3 | 2 | If Z = 1 then PC ← PC + rel                    | _  | -  | _  |         | FD       |
| BNZ/BNE rel    | 3 | 2 | If $Z = 0$ then $PC \leftarrow PC + rel$       | _  | _  | _  |         | FC       |
| BC/BLO rel     | 3 | 2 | If C = 1 then PC ← PC + rel                    | _  | _  | _  |         | F9       |
| BNC/BHS rel    | 3 | 2 | If C = 0 then PC ← PC + rel                    | _  | _  | _  |         | F8       |
| BN rel         | 3 | 2 | If N = 1 then PC ← PC + rel                    | _  | _  | _  |         | FB       |
| BP rel         | 3 | 2 | If N = 0 then PC ← PC + rel                    | _  | _  | _  |         | FA       |
| BLT rel        | 3 | 2 | If V∀N=1 then PC←PC+rel                        | _  | _  | _  |         | FF       |
| BGE rel        | 3 | 2 | If V∀N=0 then PC←PC+reI                        | _  | _  | _  |         | FE       |
| BBC dir: b,rel | 5 | 3 | If(dir:b)=0 then PC←PC+rel                     | _  | _  | _  | -+      | B0 to B7 |
| BBS dir: b,rel | 5 | 3 | If(dir:b)=1 then PC←PC+rel                     | _  | _  | _  | -+      | B8 to BF |
| JMP @A         | 2 | 1 | (PC) ← (A)                                     | _  | _  | _  |         | E0       |
| JMP ext        | 3 | 3 | (PC) ← ext                                     | _  | _  | _  |         | 21       |
| CALLV #vct     | 6 | 1 | Vector call                                    | _  | _  | _  |         | E8 to EF |
| CALL ext       | 6 | 3 | Subroutine call                                | _  | _  | _  |         | 31       |
| XCHW A,PC      | 3 | 1 | $(PC) \leftarrow (A), (A) \leftarrow (PC) + 1$ | _  | _  | dΗ |         | F4       |
| RET            | 4 | 1 | Return from subrountine                        | _  | _  | _  |         | 20       |
| RETI           | 6 | 1 | Return form interrupt                          | -  | -  | ı  | Restore | 30       |

## 4.4 Other Instructions

This section describes the other instructions.

#### **■** Other Instructions

| Mnemonic | ~ | # | Operation | TL | TH | AH | NZVC | OP code |
|----------|---|---|-----------|----|----|----|------|---------|
| PUSHW A  | 4 | 1 |           | _  | _  | _  |      | 40      |
| POPW A   | 4 | 1 |           | _  | _  | dΗ |      | 50      |
| PUSHW IX | 4 | 1 |           | _  | _  | _  |      | 41      |
| POPW IX  | 4 | 1 |           | _  | _  | _  |      | 51      |
| NOP      | 1 | 1 |           | _  | _  | _  |      | 00      |
| CLRC     | 1 | 1 |           | _  | _  | _  | R    | 81      |
| SETC     | 1 | 1 |           | _  | _  | _  | S    | 91      |
| CLRI     | 1 | 1 |           | _  | _  | _  |      | 80      |
| SETI     | 1 | 1 |           | _  | _  | _  |      | 90      |

## 4.5 F<sup>2</sup>MC-8L Family Instruction Map

This section describes the  $F^2MC-8L$  family instruction map.

#### ■ F<sup>2</sup>MC-8L Family Instruction Map

|    | APC            | ASP             | ΑÆ             | AEP            | APC              | ASP            | AA                | AEP             | 급              | T               | 급               | 급               | 급                     | Tall          | E E             | E)                    |
|----|----------------|-----------------|----------------|----------------|------------------|----------------|-------------------|-----------------|----------------|-----------------|-----------------|-----------------|-----------------------|---------------|-----------------|-----------------------|
| 4  | MOVW           | MOVW            | МООМ           | MOVM           | XCHW             | мнэх           | XCHM              | XCHM            | BNC            | BC              | ВР              | BN              | BNZ                   | BZ            | BGE             | BLT                   |
| В  | @ A            | W<br>SPA        | W<br>IX.A      | W<br>EPA       | W<br>A#CL6       | W<br>SP#d16    | W<br>IX#A116      | W<br>IP #016    | Λ #0           | χ<br>#1         | Δ/<br>#2        | Δ/<br>#3        | ν #4                  | м #5          | м #6            | χ<br>#7               |
|    | A A            | MOVW            | MOVW           | MOVW           | MOVW             | MOV            | MOV               | MOVW<br>EP#     | CALIN          | CALIN           | CALIN           | CALIN           | CALIN                 | CALIN         | CALIN           | CALIN                 |
| D  |                | WC<br>SP        | MC MC          | OW<br>EP       | MOVW             | VW<br>dip      | )VW<br>@ IX +d.p. | VW<br>@ EP A    | 3<br>R0        | 3 R1            | 3<br>R2         | 3<br>R3         | 2<br>R4               | r R5          | r R6            | 2<br>R7               |
|    | DECW           | DECW            | DECW           | DECW           | .pxd:            | MOVW           | MC                | MOVW<br>P @     | DEC 0          | DEC             | DEC 2           | DEC 3           | DEC 4                 | DEC<br>5      | DEC 6           | DEC 7                 |
| ပ  | INCW           | INCW            | INCW           | INCW           | MOVW             | MOVW<br>A,dir  | MOVW<br>Ag IX +d  | MOVW<br>AØ EP   | INC RO         | INC R1          | INC R2          | INC R3          | INC R4                | INC R5        | INC R6          | INC R7                |
| В  | BBC<br>di:0,el | BBC<br>dk:1 pel | BBC<br>db:2,el | BBC<br>dir3,e1 | BBC<br>dir:4 pel | BBC<br>db:5pel | BBC<br>chr6,rel   | BBC<br>dk:7,e1  | BBS<br>chronel | BBS<br>chr1.rel | BBS<br>chr2,re1 | BBS<br>chr3,re1 | BBS<br>chr4,re1       | BBS<br>db:5æ1 | EBS<br>checkers | BBS<br>dir7,rel       |
| ٧  | CIRB           | CIRB<br>di:1    | CIRB<br>di:2   | CIRB<br>dk:3   | CIRB<br>dir:4    | CIRB<br>dir5   | CIRB<br>dir6      | CIRB<br>d±7     | SETB<br>die:0  | SETB<br>diril   | SETB dir:2      | SETB<br>dk:3    | SETB<br>d <b>i</b> :4 | SETB dr:5     | SETES<br>dir:6  | SETB<br>d <b>k</b> :7 |
| 6  | SETI           | SEIC            | MOV<br>A@A     | MOVW<br>A@A    | DAS              | CMP<br>dir#d8  | CMP<br>@ IX +d#dB | CMP<br>@ EP #CB | CMP<br>R0#08   | CMP<br>R1#08    | CMP<br>R2#08    | CMP<br>R3#08    | CMP<br>R4#08          | CMP<br>R5#08  | CMP<br>R6#08    | CMP<br>R7#08          |
| 8  | CIRI           | CIRC            | MOV<br>@A,T    | MOVW<br>@A,T   | DAA              | MOV<br>dir#d8  | MOV<br>@ IX+d#d8  | MOV<br>@ EP #d8 | MOV<br>R0#08   | MOV<br>R1,#08   | MOV<br>R2#08    | MOV<br>R3#08    | MOV<br>R4#08          | MOV<br>R5#d8  | MOV<br>R6#d8    | MOV<br>R7#d8          |
| 7  | A PS           | V<br>PSA        | A              | A              | A#08             | Adř            | P+1               | A Ø EP          | AR0            | AR1             | AR2             | AR3             | AR4                   | AR5           | AR6             | AR7                   |
|    | MOVW           | MOVW            | OR             | ORW            | OR               | OR             | OR<br>A@IX+       | OR              | OR             | OR              | OR              | OR              | OR                    | OR            | OR              | OR                    |
| 9  | MOV<br>Apt     | MOV<br>ext.A    | ANDA           | ANDW           | AND<br>A #d8     | AND<br>A,chir  | AND<br>A Ø IX +d  | AND<br>A @ EP   | AND<br>ARO     | AND<br>AR1      | AND<br>AR2      | AND<br>A.R.3    | AND<br>AR4            | AND<br>ARS    | AND<br>AR6      | AND<br>AR7            |
|    | A              | ×               | A A            | A A            | A #OB            | Adir           | A X +d A          | AØEP A          | AR0            | AR1             | AR2             | AR3             | AR4                   | AR5           | AR6             | AR7                   |
| 2  | POPW           | POPW            | XOR            | XORW           | XOR              | XOR ,          | XOR<br>A.         | XOR<br>A@       | XOR            | XOR             | XOR             | XOR             | XOR                   | XOR           | XOR             | XOR P                 |
| 4  | PUSHW          | PUSHW           | н А,Т          | XCHW A,T       |                  | √ dich         | MOV@ K<br>+dA     | √<br>@EPA       | V<br>ROA       | V<br>R1A        | V<br>R2A        | V<br>R3A        | V<br>R4A              | V<br>R5A      | V<br>R6A        | V<br>R7A              |
|    | PU             |                 | XCH            | X X            | /<br>8           | Adir MOV       |                   | EP MOV          | MOV            | MOV             | MOV 22          | MOV 33          | MOV 24                | MOV           | MOV 86          | MOV 73                |
| 3  | REII           | CALL<br>addid6  | SUBC           | SUBCW          | SUBC<br>A#d8     | SUBC           | SUBOA@K<br>+d     | SUBC<br>A @ E   | SUBC<br>ARO    | SUBC<br>AR1     | SUBC<br>AR2     | SUBC<br>AR3     | SUBC<br>AR4           | SUBC<br>AR5   | SUBC<br>AR6     | SUBC<br>AR7           |
| 2  | RET            | JMP<br>addd6    | ADDC A         | ADDCW          | ADDC<br>A #CB    | ADDC<br>A,dir  | ADDC<br>A@ IX +d  | ADDC<br>A Ø EP  | ADDC<br>AR0    | ADDC<br>AR1     | ADDC<br>AR2     | ADDC<br>AR3     | ADDC<br>AR4           | ADDC<br>AR5   | ADDC<br>AR6     | ADDC<br>AR7           |
| 1  | AP             | D A             | РА             | PW A           | P<br>A#d8        | P. A.Air       | CMPA@K            | e<br>Aøep       | P ARO          | e<br>AR1        | P AR2           | P AR3           | P AR4                 | P ARS         | P AR6           | P AR7                 |
|    | SWAP           | A DIVU          | A CMP          | CM PW          | GW ID            | Adir           |                   | CMP             | CMP            | CMP             | CMP             | CMP             | CMP                   | CMP           | CMP             | CMP                   |
| 0  | NOP            | MULU            | ROLC           | RORC           | MOV<br>A#38      | MOV            | MOVA@K            | MOV<br>A@ EP    | MOV<br>AR0     | MOV<br>AR1      | MOV<br>AR2      | MOV<br>AR3      | MOV<br>AR4            | MOV<br>AR5    | MOV<br>AR6      | MOV<br>AR7            |
| H/ | 0              | -               | 2              | e              | 4                | 2              | 9                 | 7               | 8              | 6               | <b>V</b>        | 8               | o                     | Q             | Ш               | н                     |

## **CHAPTER 5** MASK OPTIONS

This chapter describes mask options.

5.1 Mask Options

## 5.1 Mask Options

This section describes the mask options.

#### **■** Mask Options

**Table 5.1-1 Mask Options** 

|     | Part numb                                                                                                                                                                        | per                      | MB89997                             | MB89P195                            | MB89PV190                         |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|-------------------------------------|-------------------------------------|-----------------------------------|
| No. | Specifying pro                                                                                                                                                                   | cedure                   | Specify when<br>ordering<br>masking | Specify when<br>ordering<br>masking | Fixed                             |
| 1   | Port pull un reciptore                                                                                                                                                           | 00 to P07<br>P30 to P37  | Selectable by pin                   | Selectable by pin                   | Not available                     |
| '   | 1 Port pull-up resistors                                                                                                                                                         | P00 to P03<br>P40 to P45 | Selectable by pin                   | Selectable by pin                   | Not available                     |
| 2   | Power-on reset selection - Power-on reset provi - No power-on reset                                                                                                              | ·='                      | Selectable                          | Enabled                             | Enabled                           |
| 3   | Selection of oscillation s time (at 4.2 MHz) $^{*1}$ - $2^{18}/F_{C}$ (approx. 62.4 - $2^{16}/F_{C}$ (approx. 15.6 - $2^{12}/F_{C}$ (approx. 0.98 - $2^{2}/F_{C}$ (approx. 0 ms) | ms)<br>ms)<br>ms)        | Selectable                          | Selectable                          | Fixed to $2^{16}$ /F <sub>C</sub> |
| 4   | Reset pin output - Reset output provide - No reset output                                                                                                                        | d                        | Selectable                          | Selectable                          | Output<br>enabled                 |
| 5   | Oscillation type of clock - 1 ceramic oscillator - 2 crystal oscillator - 3 CR                                                                                                   |                          | Selectable                          | Selectable                          | "1" only                          |

<sup>\*1:</sup> The oscillation stabilization delay time is generated by dividing the original clock oscillation. The time described in this item should be used as a guideline since the oscillation cycle is unstable immediately after oscillation starts. "f" indicates the original oscillation frequency.

## **APPENDIX**

The appendix describes I/O map and EPROM setting for MB89P195.

APPENDIX A I/ O Map
APPENDIX B EPROM Setting for MB89P195

## APPENDIX A I/O Map

#### Appendix A describes the I/O map.

#### ■ /O Map

| Address                            | Read/write | Register name                           | Register description                  |  |  |  |  |  |
|------------------------------------|------------|-----------------------------------------|---------------------------------------|--|--|--|--|--|
| 00 <sub>H</sub>                    | (R/W)      | PDR0                                    | Port 0 data register                  |  |  |  |  |  |
| 01 <sub>H</sub>                    | (W)        | DDR0                                    | Port 0 data direction register        |  |  |  |  |  |
| 02 <sub>H</sub> to 07 <sub>H</sub> |            | Vacancy                                 |                                       |  |  |  |  |  |
| 08 <sub>H</sub>                    | (R/W)      | STBC                                    | Standby control register              |  |  |  |  |  |
| 09 <sub>H</sub>                    | (R/W)      | WDTC                                    | Watchdog control register             |  |  |  |  |  |
| 0A <sub>H</sub>                    | (R/W)      | ТВТС                                    | Time-base timer control register      |  |  |  |  |  |
| 0B <sub>H</sub>                    |            |                                         | Vacancy                               |  |  |  |  |  |
| 0C <sub>H</sub>                    | (R/W)      | PDR3                                    | Port 3 data register                  |  |  |  |  |  |
| 0D <sub>H</sub>                    | (W)        | DDR3                                    | Port 3 data direction register        |  |  |  |  |  |
| 0E <sub>H</sub>                    | (R/W)      | PDR4                                    | Port 4 data register                  |  |  |  |  |  |
| 0F <sub>H</sub> to 13 <sub>H</sub> |            | Vacancy                                 |                                       |  |  |  |  |  |
| 14 <sub>H</sub>                    | (R/W)      | RCR1                                    | Remote-control register 1             |  |  |  |  |  |
| 15 <sub>H</sub>                    | (R/W)      | RCR2                                    | Remote-control register 2             |  |  |  |  |  |
| 16 <sub>H</sub>                    |            |                                         | Vacancy                               |  |  |  |  |  |
| 17 <sub>H</sub>                    |            |                                         | Vacancy                               |  |  |  |  |  |
| 18 <sub>H</sub>                    | (R/W)      | T2CR                                    | Timer 2 control register              |  |  |  |  |  |
| 19 <sub>H</sub>                    | (R/W)      | T1CR                                    | Timer 1 control register              |  |  |  |  |  |
| 1A <sub>H</sub>                    | (R/W)      | T2DR                                    | Timer 2 data register                 |  |  |  |  |  |
| 1B <sub>H</sub>                    | (R/W)      | T1DR                                    | Timer 1 data register                 |  |  |  |  |  |
| 1C <sub>H</sub> to 22 <sub>H</sub> |            |                                         | Vacancy                               |  |  |  |  |  |
| 23 <sub>H</sub>                    | (R/W)      | EIC1                                    | External interrupt control register 1 |  |  |  |  |  |
| 24 <sub>H</sub>                    | (R/W)      | EIC2                                    | External interrupt control register 2 |  |  |  |  |  |
| 25 <sub>H</sub> to 31 <sub>H</sub> |            | Vacancy                                 |                                       |  |  |  |  |  |
| 32 <sub>H</sub>                    | (R/W)      | EIE2                                    | External interrupt 2 enable register  |  |  |  |  |  |
| 33 <sub>H</sub>                    | (R/W)      | EIF2 External interrupt 2 flag register |                                       |  |  |  |  |  |
| 34 <sub>H</sub> to 7B <sub>H</sub> |            | Vacancy                                 |                                       |  |  |  |  |  |

| Address         | Read/write | Register name | Register description               |
|-----------------|------------|---------------|------------------------------------|
| 7C <sub>H</sub> | (W)        | ILR1          | Interrupt level setting register 1 |
| 7D <sub>H</sub> | (W)        | ILR2          | Interrupt level setting register 2 |
| 7E <sub>H</sub> | (W)        | ILR3          | Interrupt level setting register 3 |
| 7F <sub>H</sub> | _          | ITR           | Interrupt test register            |

#### Note:

<sup>—</sup> indicate the vacant area, it is not used.

#### **APPENDIX B EPROM Setting for MB89P195**

#### Appendix B describes the EPROM setting for MB89P195.

#### **■** EPROM Setting for MB89P195

MB89P195 is provided with the function corresponding to MBM27C256A by EPROM setting. The setting can be performed by writing program data with general-purpose EPROM writer through adaptor for exclusive use .

However, the electric signature mode is not supported.

#### Setting

- (1) Set the EPROM writer to MBM27C256A.
- (2) Load the program data from address 4000<sub>H</sub> to address 7FFF<sub>H</sub> of EPROM writer.

The data is loaded from address  $0C000_H$  to address  $0FFFF_H$  in the operation mode, and from address  $4000_H$  to address  $7FFF_H$  in the EPROM mode.)

(3) Write the data from 0000<sub>H</sub> with the EPROM writer.

(Writing to the correct address cannot be performed other than from 0000<sub>H</sub>.)

The memory space in the EPROM mode is as follows:



#### O ROM writer adapter (Sun Hayato Co., Ltd.)

| Package     | Model No. of applicable adapter |
|-------------|---------------------------------|
| FPT-28P-M02 | ROM-28SOP-28DP-8L               |

## **INDEX**

The index follows on the next page.

This is listed in alphabetic order.

## Index

| Numerics                                          | interrupt58                                         |
|---------------------------------------------------|-----------------------------------------------------|
| 16-bit data in memory, arrangement of16           | L                                                   |
| A                                                 | list of port function28                             |
| arrangement of 16-bit data in memory16            | low-power consumption mode 60                       |
| В                                                 | M                                                   |
| block diagram5, 25, 32, 39, 43, 45, 48, 51        | machine clock control block diagram19               |
| branch instruction                                | mask option72                                       |
|                                                   | MB89P195, EPROM setting for                         |
| С                                                 | memory space14                                      |
| clock pulse generator54                           | 0                                                   |
| CPU, internal register in16                       |                                                     |
| _                                                 | objective and intended reader                       |
| D                                                 | •                                                   |
| description27                                     | operation, description of                           |
| description of function29                         | other instruction                                   |
| description of operation21, 36, 47, 52            | Р                                                   |
| description of register20, 26, 40, 44, 46, 49, 51 | pin assignment6                                     |
| description of register detail33                  | pin function description                            |
| E                                                 | pin state for sleep, stop and reset                 |
|                                                   | port function, list of                              |
| EPROM setting for MB89P19576                      | precaution for external-interrupt circuit           |
| external-interrupt circuit, precaution for42      | product series                                      |
| F                                                 | R                                                   |
| F2MC-8L family linstruction map70                 |                                                     |
| feature2                                          | register39, 51                                      |
| function, description of29                        | register list                                       |
|                                                   | register, description of 20, 26, 40, 44, 46, 49, 51 |
| Н                                                 | reset control section                               |
| handling device12                                 | reset operation                                     |
| I                                                 | reset source57                                      |
| I/O map74                                         | Т                                                   |
| intended readerand objectivei                     |                                                     |
| internal register in CPLI                         | transfer instruction64                              |

CM25-10133-2E

## **FUJITSU SEMICONDUCTOR • MICROCONTROLLER** MANUAL

F<sup>2</sup>MC-8L FAMILY 8-BIT MICROCONTROLLER MB89990 Series HARDWARE MANUAL

March 2000 the second edition

Published FUJITSU LIMITED Electronic Devices

Edited Technical Communication Dept.

# **FUJITSU**



FUJITSU SEMICONDUCTOR F<sup>2</sup>MC-8L FAMILY 8-BIT MICROCONTROLLER MB89990 Series HARDWARE MANUAL